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Одна из причин, побудивших автора напи- 
сать эту книгу, — «осознание собственного 
бессилия в поисках сиюминутного практи- 
ческого смысла при чтении классических 
сочинений по теории тестирования...», в 
особенности когда ты в поисках работы и 
время дорого. «Наиболее эффективный 
подход для тренинга тестировщиков — дать 
им практический инструментарий, поставить 
в нужную сторону мозги — ив бой...» 


Эта книга и есть тот самый практический 
инструментарий. Здесь вы найдете прорабо- 
танную структуру, профессиональное изло- 
жение темы, множество примеров и советов, 
а также «...легион того, о чем вам напрямую 
не напишут и не скажут, но что может быть не 
менее важно для выживания в софтверной 
компании, чем профессиональные знания». 


Но это не все. Особенность книги в том, 
как излагается материал. Роман Савин отка- 
зался от традиционных канонов написания 
учебных пособий и превратил книгу в живую 
непринужденную беседу, насыщенную шут- 
кой и иронией, не чуждую отступлений и да- 
же воспоминаний, которые тем не менее 
встроены в контекст и работают на предмет 
как иллюстрационный материал. 

Читать книгу интересно и весело. Убеди- 
тесь в этом сами. 
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Моим любимым Маме и Марине посвящается, 
чьи любовь и вера — самое драгоценное, 


что я получил от жизни... 


ВВЕДЕНИЕ 


Основа бэкграунда тестировщика — 
это логика, здравый смысл и жизненный опыт. 


Народная мудрость 


Дорогие друзья, 


я написал эти лекции по практике тестирования, чтобы просто и 
задушевно рассказать вам основные вещи, которые понадобятся 
для успешного старта и не менее успешной работы в интер- 
нет-компании в качестве тестировщика. 


Я также уверен, что тихие вечера, проведенные за чтением моего 
скромного труда, откроют много полезного любому человеку, имею- 
щему отношение к процессу создания программного обеспече- 
ния (ПО), так как качество, как тишина в кинозале, — дело общее. 


Отдельной группой благодарных читателей, несомненно, выступят 
профессиональные рекрутеры, нанимающие народ для удар- 
ного труда в интернет-компаниях. 


Кроме того, я Надеюсь, что материал будет просто интересен всем, 
кто пользуется Интернетом и желает узнать, как работают интер- 
нет-компании. 


Приведя десятки примеров, я попытался максимально проил- 
люстрировать материал, так, чтобы даже сугубо технические 
детали были понятны самому широкому кругу читателей. 


Моя цель — не показать, что я знаю материал (как это делает- 
ся при защите диплома), а помочь ВАМ узнать материал, и ил- 
люстрации (текстовые и графические) — это лучшее вспомога- 
тельное средство, для того чтобы 


• легче понять и усвоить смысл сказанного и 
• оставить в памяти якорь ассоциации между иллюстра- 
цией и проиллюстрированной мыслью. 


Идем дальше. 


Помимо просьб друзей, требований жены и намечающегося кри- 
зиса среднего возраста на подвиг меня толкнуло то, что в начале 
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своей работы не раз и не два я пытался осилить классические со- 
чинения по теории тестирования, но каждый раз осознание соб- 
ственного бессилия в поисках сиюминутного практического 
смысла не давало мне дочитать очередной фолиант. 


Пример 
Безработная девушка Маша П. захотела стать бухгалтером. Она приходит 
на соответствующие курсы, но вместо прикладных, оплачиваемых знаний 
по назначению счетов и инструкций МНС ей преподают теорию макроэко- 
номики и историю бухгалтерии. Маша думает, что она не сможет осилить 
бухгалтерию, и бросает курсы. В итоге Родина теряет потенциально бле- 
стящего бухгалтера и обретает реально радикального члена компартии. 


Я преклоняюсь перед предметом "история". О пользе Теории (с 
большой буквы "Т") и говорить не приходится, но, как я убедился 
на своем многолетнем опыте работы и преподавания, наиболее 
эффективный подход к тренингу тестировщиков заключается 
в том, чтобы дать им практический инструментарий, напра- 
вить мозги в нужную сторону — и в бой, а теоретические мета- 
ния тридцатилетней давности можно почитать на досуге, после 
того как устроился на работу. 


Кроме того, есть 


• политические нюансы работы; 

• распространенные ошибки менеджмента; 

• продюсеры, программисты и релиз-инженеры, работу ко- 
торых нужно понимать изнутри, — 


В общем легион того, о чем вам напрямую не напишут и не 
скажут, но что может быть не менее важно для выживания в соф- 
тверной компании, чем профессиональные знания. 


Будучи человеком честным и в некоторой степени благородным, 
признаюсь, что позаимствую классическое начало книг о тести- 
ровании, заключающееся в трусливом: "Не используйте знания 
из этой книги, если речь идет о тестировании критического ПО ". 


Итак, 


я свидетельствую, что все, о чем я расскажу, действительно ра- 
ботает, и работает именно так в крупнейших западных интернет- 
компаниях; 

я также свидетельствую, что все, о чем я расскажу, в силу объ- 
ективных причин не может на 100 процентов гарантировать ПО 
от наличия проблем. 


12 Введение 


Поэтому сразу предупреждаю: эта книга не предназначена для 
тех, кто собирается тестировать критическое ПО, связанное, 
например, с мониторингом работы сердечной мышцы, или 
ПО для поражения точечных целей в странах с большими за- 
пасами нефти. 


Серьезно, если речь идет о жизни людей, лучше скормите эту 
книгу своему попугаю-жако (о попугаях позже). 


Два важных момента: 


1. В отличие от деятельности юридической деятельность тести- 
ровочная (для коммерческих проектов) не регулируется нор 
мативными актами или другими формальными источниками. 
Поэтому нет обязательных для исполнения правил о том, как 
эффективно протестировать ПО, какие документы нужно создать 
и в какой форме они должны быть. 


Никто не возьмет вас за горло из-за того, что ваш тест-план не 
соответствует букве некого закона, пролоббированного некой 
продажной шкурой из не менее продажной фракции в интересах 
всем хорошо известной финансово-промышленной группы М. 


В цехе тестировщиков ничто не является догмой (поѓЛіпо 15 5её т 
ѕіопе) и построение добротной системы поиска и превентиро- 
вания ошибок в ПО полностью отдается на откуп профессиона- 
лизму, добросовестности и творчеству тех, кто работает в кон- 
кретной интернет-компании. 


Поэтому 


многие вещи, о которых пойдет речь (подходы, документы, про- 
цессы, даже названия), 


• содной стороны, имеют огромное количество вариаций в 
существующих интернет-компаниях и, 

• с другой — могут практически использоваться в предло- 
женной форме или, еще лучше, быть подогнанными вами 
под ту компанию, в которой вы работаете или, несомнен- 
но, будете работать в ближайшем будущем. 


2. "То, что русскому хорошо, — для немца смерть". По аналогии: 


• подходы к тестированию, 
• степень формализации процессов и 
• используемые документы, 
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которые эффективно работают в крупных устоявшихся интернет- 
компаниях, могут быть неприемлемы для интернет-стартапов 
(5іағіир — молодая, амбициозная, многообещающая компания, 
живущая, как правило, короткую, но яркую жизнь), и наоборот. 


Исходя из того что подавляющее большинство интернет-ком- 
паний — это стартапы, говорить будем о том, как эффективно 
провести тестирование и организовать процессы по улучшению 
качества именно в стартапах с прицелом на то, чтобы заложить фун- 
дамент департамента качества (ОА Фератітеті) для крупной устояв- 
шейся интернет-компании, стать которой мечтает каждый стартап. 


Идем дальше. 


Вопрос дня: Что самое главное в нашем деле? 
Ответ дня: РЕЗУЛЬТАТ! 


Человек может быть прекрасным семьянином, увлекаться фото- 
графией и превосходно петь арию "ато Ато" из "Травиаты", 
но единственная и неповторимая прелесть его как тестиров-щика 
— это РЕЗУЛЬТАТ. 


К вопросу о постановке мозгов и попугаях: 


перед покупкой своего попугая-жако Василия я прочитал кучу 
литературы, но лишь одна мысль позволила мне осознать самое 
главное (в смысле домашних попугаев): 


"У вас есть хобби, друзья и работа. У вашего попугая есть 
только вы ". 


Так вот по аналогии: 


Вы можете быть наделены множеством самых прекрасных и 
вечных добродетелей. Но в вашей работе тестировщика есть 
единственный смысл — РЕЗУЛЬТАТ. 


Каков же этот РЕЗУЛЬТАТ (пишу "РЕЗУЛЬТАТ" заглавными бук- 
вами в последний раз)? 


Спрашиваете —Щ отвечаем: 


результатом работы тестировщика является счастье конеч- 
ного пользователя (сказать "удовлетворение клиента" как-то язык 
не поворачивается). Причем "счастье" не в глобальном его значе- 
нии, а та его часть, которая связана с качеством вашего продукта. 
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Например, 
некто Виктор Буянов бродит по Интернету в поисках диска с москов- 
ским кониертом Билли Джоела. Вот он наконец находит то, что искал, 
заполняет все необходимые формы и нажимает кнопку "Купить". Если 
• на следующей странице будет написано: "Дорогой Виктор, мы 
получили ваш заказ, ждите посылку" и 
• через неделю почтальон принесет сам диск, 
то честь и хвала вам как тестировщикам. 


Если же 
на следующей странице красуется "500 — тета! Ѕегуег Еггог" 
(внутренняя ошибка сервера номер 500)... и тишина, 


то пишите объяснительные. 


Идем дальше. 


Я дам вам знания, с которыми можно пройти интервью, получить 
интересную работу и начать новую жизнь, но кроме прикладных 
моментов следует твердо знать, что тестировщикам большую 
часть заработной платы платят за честность, так как именно 
нашему брату оказано доверие сказать "Поехали". И даже абсо- 
лютно далекий от тестирования господин Буянов косвенно под- 
твердил своим выбором мои слова (дальше поются строчки из 
припева песни Билли Джоела "Честность" ("Нопеѕѓу")): 


Нопеѕіу 15 Рағаіу еуег йеагА. 
Апа тоѕіу йа [ пее4 гот уои. 
(Честность — это 50% + 1 единица того, что я жду от тебя.) 


Перевожу тему. 


Будет дано множество примеров того, что мы работаем на некий 
онлайн-стартап ууу. 4ейор.т5 (75 — это не глобальный домен, 
как сот или ги, а мои инициалы). 


Многие термины будут написаны по-английски с немедленным 
русским переводом и наоборот. Знание родной терминологии по- 
может работе в инофирме. 


Пользуясь случаем, хочу поблагодарить (в алфавитном порядке): 


Алекса Хатилова (Уайоо!) за превосходные лекции, многочасо- 
вые консультации по телефону и демонстрацию силы аналогий и 
примеров из жизни и 

Никиту Тулинова (5ии Місгоѕуѕіетѕ), который принял меня, как 
брата, и наставил на путь истинный. 


Итак, в путь. Если что, пишите на дае5Каетай.сот. 


ЧАСТЬ 1 


ЧТО ТАКОЕ БАГ 
• ЦЕЛЬ ТЕСТИРОВАНИЯ РЕСОБЕО 
. ИСКУССТВО СОЗДАНИЯ ТЕСТ-КЕЙСОВ 


• ЦИКЛ РАЗРАБОТКИ ПО 


— Баг иль не баг? 
Вот в чем вопрос. 


ЧТО ТАКОЕ БАГ 


® ОПРЕДЕЛЕНИЕ БАГА 

• ТРИ УСЛОВИЯ ЖИЗНИ И ПРОЦВЕТАНИЯ БАГА 
• ЧТО ТАКОЕ ТЕСТИРОВАНИЕ 

• ИСТОЧНИКИ ОЖИДАЕМОГО РЕЗУЛЬТАТА 

• ФУНКЦИОНАЛЬНЫЕ БАГИ И БАГИ СПЕКА 


ШЕЕ закон исключенного третьего гласит, что любая 
вещь — это либо а, либо не-а. Третьего не дано, т.е. если у 
вас есть часы "Брегет" за номером 5, то любая вещь в этом мире 
будет либо вашими часами "Брегет" за номером 5, либо чем-то 


другим. 


Представим себе конвейер, в конце которого стоим мы. Лента 
конвейера движется, и перед нами по очереди появляется по од- 
ному предмету. Задача проста — ожидать появления ваших часов 
"Брегет" за номером 5 и говорить "баг" при появлении любого 
предмета, отличного от них. 


Нетрудно догадаться, что такие предметы, как 


• пакет кефира; 

• будильник "Слава"; 

• буклет с предвыборными обещаниями кандидата в прези- 
денты Н., 


будут для нас багами. 


Далее. Рассмотрим, что объединяет следующие ситуации. 
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1. Девушка рекламирует себя как хорошую, на все руки хо- 
зяйку, а утром выясняется, что она даже яичницу пожарить 
не в состоянии. 

2. Вы купили книгу по интернет-тестированию, а в ней рас- 
сказывается о приготовлении яичницы. 

3. Девушка из пункта 1 прочитала книгу из пункта 2, но яич- 
ница пересолена. 


Если возвыситься над яичницей, фигурирующей в каждом из 
трех пунктов, и абстрагироваться от женщин, карт и вина, то мы 
увидим, что общее — это отклонение фактического от ожи- 
даемого. 


Разбор ситуаций. 


1. Ожидаемый результат -— девушка умеет готовить. 
Фактический результат — утро без завтрака. 

2. Ожидаемый результат — знания по тестированию. 
Фактический результат — знания по кулинарии. 

3. Ожидаемый результат — яичница будет приготовлена. 
Фактический результат — еще одно утро без завтрака. 


Определение бага 


Итак, 


баг (рив) — это отклонение фактического результата (асіиа/ 
тезий) от ожидаемого результата (ехрес1е4 гезий). 


В соответствии с законом исключенного третьего у нас есть баг 
при наличии любого фактического результата, отличного от 
ожидаемого. 


Три условия 
жизни и процветания бага 


Конкретный баг живет и процветает лишь при одновременном 
выполнении всех трех условий: 


1. Известен фактический результат; 

2. Известен ожидаемый результат; 

3. Известно, что результат из пункта 1 не равен результату из 
пункта 2. 


Что такое баг 19 


Совет дня: каждый раз, когда возникает ситуация, в которой не 
совпадают фактическое и ожидаемое, — мысленно штампуйте 
фактическое словом "баг". Постепенно это войдет в привычку и 
станет рефлексом. Для ментальной тренировки не имеет значе- 
ния, насколько мелочны, низки и сиюминутны ваши ожидания, 
главное — приобретение автоматизма. 


Примеры багов из жизни: 


1. Бутерброд падает маслом вниз. 

2. Подхалимы и говоруны имеют намного больше шансов на повыше- 
ние, чем скромные честные труженики. 

3. Несоответствие миловидной внешности и змеиной сущности. 

4. Попугай воспроизводит на людях худшее из словарного запаса хо- 
зяина. 

5. Автомобили российского производства. 

6, Кот Бегемот в фильме В. Бортко "Мастер и Маргарита". 


Идем дальше. 


Что такое тестирование 


Любое тестирование — это поиск багов. Испытываем ли мы 
новую соковыжималку, наблюдаем ли за поведением подруги 
или занимаемся самокопанием — мы ищем баги. Баги находятся 
следующим образом: 


1. Мы узнаем (или уже знаем) ожидаемый результат; 
2. Мы узнаем (или уже знаем) фактический результат; 
3. Мы сравниваем пункт 1 и пункт 2. 


Как видно, каждый из нас уже является тестировщиком, так как 
разного рода осознанные и неосознанные проверки, осуществ- 
ляемые нами и в отношении нас, являются неотъемлемой частью 
жизни, просто раньше мы непрофессионально качали головой и 
выдавали тирады о несправедливости мира, но зато теперь в слу- 
чае несовпадения фактического и ожидаемого мы будем с улыб- 
кой мудреца смотреть на дилетантов, хлюпающих носами на мо- 
сковском ветру, и тихо, но веско (как дон Карлеоне) говорить: 
"Та-а-к, еще один баг". 


Для иллюстрации правильного подхода приведу в пример одного 
моего друга, который выстроил целую систему доказательств тезиса, 
что люди и компьютеры созданы по одному образцу. Основой его аргу- 
ментации явился тот факт, что и те и другие имеют физическую обо- 
лочку (тело/железо) и неосязаемое составляющее, управляющее ею 
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(душа ТО). Соответственно болезни тела он называл багами в железе, 
а проблемы с головой — багами в ПО и очень сожалел, что ПО людей, 
управляющих этим миром, состоит в основном из багов... 


Теперь вспомним о том, что есть компьютерное ПО и что нам 
нужно научиться его тестировать. 


С фактическим результатом здесь более или менее понятно: нужно 
заставить систему проявить себя и посмотреть, что произойдет. 


Сложнее дело обстоит с ожидаемым результатом. 


Источники ожидаемого результата 


Основными источниками ожидаемого результата являются: 


1. Спецификация. 

2. Спецификация. 

3. Спецификация. 

4. Спецификация. 

5. Жизненный опыт, здравый смысл, общение, устоявшиеся 
стандарты, статистические данные, авторитетное мнение и др. 


Спецификация на первой— четвертой ролях — это не ошибка, а 
ударение на то, что спецификация для тестировщика — это: 


• мать родная, а также 
* Друг, 

• товарищи 

• брат. 


Спецификация важна для программиста и тестировщика так же, 
как постановление пленума ЦК для коммуниста. 


Спецификация — это инструмент, с помощью которого вы смо- 
жете выпустить качественный продукт и прикрыть свою спину (в 
оригинале звучит как СҮА или соуег уоиг аѕѕ). 


Итак, что же это за зверь? 


Спецификация (или ѕрес — читается "спек". Далее употребляется 
в мужском роде) — это детальное описание того, как должно 
работать ПО. Вот так, ни много ни мало. 


В большинстве случаев баг — это отклонение от специфика- 
ции (я говорю о компаниях, в которых спеки в принципе сущест- 
вуют и ими пользуются). 


Что такое баг 21 


Пример 
Пункт 19.а спека #8724 "О регистрации нового пользователя" устанав- 
ливает: 


«Поле "Имя" должно быть обязательным. Страница с ошибкой должна 
быть показана, если пользователь посылает регистрационную форму 
без заполнения указанного поля». 


В общем все просто: 


• тестировщик идет на страничку с регистрационной формой; 
• кликаетлинк "Регистрация"; 

• заполняет все обязательные поля, кроме поля "Имя"; 

• нажимает на кнопку "Зарегистрироваться". 


Если ошибка не показана и регистрация подтверждается, то это есть 
момент истины и нужно рапортовать баг (їе а Бид). 


Если ошибка показана, то относительно пункта 19.а на некоторое 
время можно успокоиться. Мы поймем, почему можно успокоиться 
лишь на некоторое время при разговоре о регрессивном тести- 
ровании. .. 


Функциональные баги и баги спека 


Допустим, что ошибка не была показана и мы имеем классиче- 
ский случай функционального бага (ўипсіопа! Бие, или баг 
обыкновенный), т.е. бага, вскормленного на несоответствии 
фактической работы кода и функционального спека. 


Если вы внимательно читали пункт 19.а, то не могли не заметить 
(шутка), что непонятно, какое должно быть сообщение об ошибке 
(егтог теѕѕаве), т.е. фактически решение отдано на откуп про- 
граммисту и он может предусмотреть, что при соответствующей 
ситуации код выдаст: 


• НЕинформативное сообщение "Ошибка" и оставит пользо 
вателя ломать голову над тем, что он сделал неправильно, 
либо 

• информативное сообщение «Пожалуйста, введите ваше имя 
и нажмите кнопку "Регистрация"» 


и в любом случае формально будет прав, так как спецификация 
не детализирует текста ошибки. 


Кстати, несколько лет назад был случай, когда программисты в специ- 
альном ПО, разработанном для американских тюрем, оставили "рабо- 
чее" название кнопки, причем тюремщикам идея так понравилась, что 
они просили ничего не исправлять. Надпись на кнопке была: "Освобо- 
дить подонка". 
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В общем сложилась ситуация, когда сама спецификация имеет 
проблему, так как мы ожидаем (или по крайней мере должны 
ожидать), что в спеке будут подробности о тексте ошибки, а в 
реальности их там нет. Так и запишем — "баг в спецификации" 


(брес Бие). 


Кстати, вот варианты развития ситуации с проблемным спеком: 


а. Скорее всего программист все же напишет информативное сооб 
щение об ошибке. Ваше дело послать е-мейл продюсеру (продю 
сером в интернет-компании называют товарища, создающего 
спеки), чтобы тот внес текст, уже написанный программистом, в 
пункт 19. а. 

6. Если программист написал нечто противоречащее здравому смыслу 
или стандарту, принятому в вашей компании, рапортуйте баг. 

в. Может случиться так, что вы не заметили проблемы в спеке и не заме 
тили, как программист написал сообщение об ошибке, противореча 
щее здравому смыслу или стандарту, принятому в вашей компании. 


Кстати, вот две релевантные политически важные вещи: 


1. Как правило, работа в стартапе — это уникальный опыт, когда тяже- 
лый труд сочетается с радостью созидания, расслабленной обста- 
новкой (я, например, уже многие годы хожу на работу в шортах) и 
окружающими вас милыми, веселыми людьми. Но бывают нештат- 
ные ситуации (например, работа не сделана в срок или сделана не- 
качественно), и, когда дело дойдет до выяснения "кто виноват" и 
"что с ним сделать", многие из ваших коллег перестанут быть ми- 
лыми, веселыми людьми и активно начнут вешать собак друг на 
друга. Так вот, чтобы одну из этих собак не повесили на вас, посы- 
лайте е-мейлы, сохраняйте их и ответы на них и при случае пересы- 
лайте их заинтересованным сторонам. Пригодятся те е-мейлы в 
дальнейшем — хорошо, не пригодятся — еще лучше, тем более что 
каши они не просят, а сидят себе тихо и малодушно в своих фолде- 
рах и ничего не ждут от этой жизни. 

2. Каждый должен заниматься своим делом и отвечать за свой участок 
работы. В случае если спек сделан некачественно, то лучше под- 
нять тревогу с рассылкой е-мейлов, чем делать допущения относи- 
тельно того, как должно работать ваше ПО. 


Перед завершением темы об ожидаемом и фактическом результа- 
тах рассмотрим примеры других источников ожидаемого резуль- 
тата, кроме спеков. 


1. ЖИЗНЕННЫЙ ОПЫТ 


Как справедливо отметил Борис Слуцкий: "Не только пиво-раки 
мы ели и лакали". Мы также учились и работали, любили и нена- 
видели, верили политикам и не слушались родителей, в общем 
приобретали жизненный опыт (включая опыт работы). Так вот этот 
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опыт настолько полезен в нашем черном деле, что для демонстра- 
ции уважения к идее о его полезности (вместе с логикой и здравым 
смыслом) я вынес ее в качестве эпиграфа во Введении. Дело в том, 
что тестирование ПО — это то самое тестирование (которое мы 
делаем постоянно), но только в отношении ПО. И моя задача 
заключается лишь в том, чтобы дать вам основные концепции и 
практический инструментарий по интернет-тестированию и помочь 
их интеграции с тем, что у вас уже есть, — с жизненным опытом. 


2. ЗДРАВЫЙ СМЫСЛ (дитя жизненного опыта и соответственно 
внук "ошибок трудных") 


Это один из наших главных союзников, порой даже и при нали- 
чии спека. Например, вы тестируете веб-сайт, где пользователь 
может загрузить (ироаа) свои цифровые фотографии. Спек гово- 
рит, что пользователь может загрузить лишь одну фотографию за 
раз. А что, если у него таких фотографий 2007 Будет он счастлив? 
Что делаем? Правильно: пишем е-мейл ж рғоаисегѕ(@іеѕіѕћор.гѕ с 
предложением о включении в спек функциональности, позво- 
ляющей пользователю загружать цифровые фотографии оптом. 
Кстати, баг такого рационализаторского плана лицемерно назы- 
вается не багом, а Реажиге Кециез ("запрос об улучшении" — пока 
остановимся на таком переводе). 


3. ОБЩЕНИЕ 


Даже самый лучший спек может вызвать необходимость в уточ- 
нениях. А что, если спека нет вообще? Наш ответ: общение. Со- 
ветуйтесь с коллегами. Уточняйте и обсуждайте. Одна голова хо- 
рошо, а две лучше. 


4. УСТОЯВШИЕСЯ СТАНДАРТЫ 


Как правило, после регистрации, пользователь должен получить 
е-мейл с подтверждением. Если спек не упоминает о таком е-мейле, 
вы можете потребовать дополнить его на основании сложившей- 
ся практики. 


5. СТАТИСТИЧЕСКИЕ ДАННЫЕ 


Было установлено, что средний пользователь теряет терпение, 
если уер раве (веб-страница) не загружается в течение 5 секунд. 
Эти данные можно использовать, проводя ре’огтапсе іеѕііпе 
(тестирование скорости работы всей системы либо ее компонента). 
Как говорят американцы: "Үоиғ иѕег 15 јиѕі опе сЇіск амау јғот уоиг 
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сотрешог" ("Ваш пользователь находится на расстоянии в один 
клик от вашего конкурента"). Успех вашего проекта — это счастли- 
вые пользователи. Превышение 5 секунд — это превращение веб- 
сайта в зал ожиданий, в котором вряд ли кто захочет находиться. 


6. АВТОРИТЕТНОЕ МНЕНИЕ 


Это может быть, например, мнение вашего начальника. 


7. ДР. 
Другие. 


Отметим, что баг (Ри буквально пе еводится как "жук" или 
› 8; оу р у 
"букашка". 


Теперь, как я и обещал, немного истории. 


Согласно фольклору, баги вошли в лексикон компьютерщиков после 
случая, происшедшего в Гарвардском университете в 1947 г. После то- 
го как на реле прадедушки ПК Марка І! присел отдохнуть мотылек, один 
из контактов слегка коротнуло и весь 15-тонный агрегат со скрежетом 
остановился. Инженеры проявили милосердие и извлекли мотылька, 
после чего аккуратно зафиксировали его скотчем в журнале испытаний 
с комментарием "Первый фактический случай найденного жука" ("Еігѕї 
асша! саѕе оѓ бид Бетд оипа!"!. 


Итак, 


Краткое подведение итогов 


1. Баг — это отклонение фактического результата от ожидаемого. 

2. Главный источник ожидаемого результата в интернет-компании — 
это спецификация. 

3. Спецификации сами не без греха, и в этом случае, как и в случае 
полного их отсутствия, у нас есть здравый смысл, устоявшиеся 
стандарты, опыт работы, статистика, авторитетное мнение и др. 


Задания для самопроверки 


1. Ищите баги в чем угодно, введите это слово в свой лексикон и 
расписывайте самые яркие из них на листе бумаги по схеме: 
Ожидаемый результат/Фактический результат. 

2. Подумайте, какие еще источники ожидаемого результата могут 
быть в работе тестировщика. 

3. Побродите по Интернету, порегистрируйтесь (ими. уаһоо.сот, 
им. һоітаі.сот и т.д.) и составьте список обязательных полей 
(гедиігеа їе!Іаѕ) на регистрационных формах. 


ЦЕЛЬ ТЕСТИРОВАНИЯ 
РЕСОБЕВ 


* ЦЕЛЬ ТЕСТИРОВАНИЯ 

* ЧЕРНАЯ МАГИЯ И ЕЕ НЕМЕДЛЕННОЕ РАЗОБЛАЧЕНИЕ 
* ИДЕЯ О СТАТИСТИКЕ ДЛЯ ПОСТРЕЛИЗНЫХ БАГОВ 

• ТЕСТИРОВАНИЕ И СА (Сиайу Аззигапсе) 


Б° рассусоливаний и теоретизирования я прямо скажу, для 
чего все это нужно. 


Цель тестирования 


Цель тестирования — это нахождение багов до того, как их 
найдут пользователи. 


Другими словами, вклад тестировщика в счастье пользовате- 
ля — это приоритет в нахождении багов. 


Пусть в мире, где история искажена, ценности поруганы, а исти- 
ны ненадежны, слова, сказанные выше, будут скалой, в прочно- 
СТИ которой ВЫ будете постоянно убеждаться. 


А теперь: 


Черная магия 
иее немедленное разоблачение 


Есть две концепции, о которых необходимо знать, потому что 
они распространены и вредят как тестировщикам в частности, так 
и компании в целом. 
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ПЕРВАЯ КОНЦЕПЦИЯ: цель тестирования — это 100%-я про- 
верка ПО. 


РАЗОБЛАЧЕНИЕ ПЕРВОЙ КОНЦЕПЦИИ 


Вот вам код, написанный на языке программирования Руѓлоп 
(здесь и далее номер является номером строки для удобства ссы- 
лок и не принадлежит к коду, за знаком # следует комментарий 
для данной строки): 


1. иѕег три = ғау іприі ("И/ћаї 15 уоиг іоіет атта!?") # 
"Введите название вашего тотемного животного". 


2. іЃиѕег трш == "ғов": # ЕСЛИ пользователь ввел "лягушка", 
3. рипЕ "Үои ргоба Му Пе отееп соо!" # вывести на 
экран "Вероятно, вам нравится зеленый цвет". 


ейГ изег_ три! == "ом": # ЕСЛИ пользователь ввел "сова", 
ритЕ "Үои ргофа у ПКе отеу соог" # вывести на 
экран "Вероятно, вам нравится серый цвет". 


м > 
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ейГизег три! == "Беаг ": # ЕСЛИ пользователь ввел "медведь", 
7. рипЕ "Үои ргоба р ПКе Бгомп соог" # вывести на 
экран "Вероятно, вам нравится коричневый цвет". 


8 ейѓиѕег три == "": # ЕСЛИ пользователь не ввел никаких 
данных, 

9. рипЕ "РгоБа М, уои оп" кпоу мйа! 15 уоиг іоіет 
атта!" # вывести на экран "Вероятно, вы не знаете свое 
тотемное животное". 


Это маленькая, симпатичная и на первый взгляд никчемная про- 
грамма послужит нам для того, чтобы мы увидели 4 условия 
(сопайіопѕ), одно из которых заработает, если мы ее запустим. 
Если условие верно, например, пользователь ввел "ос", то, как 
за преступлением — наказание (в идеальном случае), наступает 
последствие — выполнение условия (конечно, если код 
работает) — вывод на экран текста "Уои ргоба у Ке етееп 
соот". Ежу понятно, что для тестирования нам нужно проверить 
все 4 условия. 


1. Ввести "ое". 
2. Ввести "оу//". 
3. Ввести "Беаг". 
4. Ничего не вводить, а просто равнодушно нажать Еиѓег. 
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Однако если ввести "лейселос" ("еж"), то Руілоп по-английски 
(т.е. без всякого сообщения) закончит выполнение программы. 
Итак, добавим к нашим четырем условиям игольчатое пятое: 


5. Любой ввод, отличный от ввода 1—4 включительно. 


Постановка мозгов 

Везде, где есть ввод (трий данных, у нас есть два пути: 
1. Ввод действительных данных (уа іпри?). 
2. Ввод недействительных данных (іпуаііа трий. 


Пустой ввод (№Ї при) может принадлежать как к действительному, 
так и кнедействительному вводу в зависимости от спецификации. 


Например, при регистрации в поле для Имени буквы (Іейегѕ) или в со- 
четании буквы и пробелы (ме ѕрасе) — это действительный ввод, 
цифры (питбегѕ), специальные знаки (ѕресіа! сһагасіегѕ, например "&") 
Ш/или пустой ввод — это недействительный ввод. Если спек не делает 
уточнений, что есть действительный и недействительный ввод, посы- 
лайте е-мейл продюсеру, а если спека нет в принципе, то полагайтесь 
на пункт 5 источников из предыдущей лекции. 


Итак, у нас есть пять УСЛОВИЙ, и нам вполне по силам проверить 
каждое из них. 


Что, если условий у нас 1000? 


Пример 
1. юге іп гапде( 1000): # для каждого номера от 0 до 999 


2. рипЕ "Му питбег іѕ "+5 (те) # напечатать значение номера. 
Первым значением вывода будет "Му питфег 15 0". 
Последним значением вывода будет "Му питьег 15 999 ". 


Допустим, что мы должны протестировать каждое из 1000 кон- 
кретных значений вывода. Ожидаемым результатом первого вит- 
ка цикла будет 0, второго — 1, энного — ўл - 1). 


Если кому-то проверка 1000 ожидаемых результатов покажется 
терпимой задачей, то мы можем привести пример со встроенным 
циклом: 


Пример (ао поЁйу й аі поте — не пытайтесь запустить этот код на 
своем компьютере!) 

1. юге іп гапде( 1000): #Оля каждого номера от 0 до 999 

2. Тогйет т гапде( 1000): # для каждого номера от 0 до 999. 

З. атоипі =те + пет # сложить два значения. 

4. рт "Сумма равна "”^атоипЁ# напечатать значение суммы. 
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В итоге получается миллион (1000 х 1000) ожидаемых результатов. 


Добавим масла в огонь: в большинстве случаев с реальным ПО 
мы интегрируем одни части кода с другими и в итоге получаем 
столько вариантов конкретных значений ожидаемых результатов, 
что на 100%-ю проверку не хватит и пяти жизней. Шести жизней 
хватить должно, но они будут самыми печальными из всех исто- 
рий о бессмысленном существовании. 


Постановка мозгов 


В мире с ограниченными ресурсами (например, время на тестирова- 
ние) 100%-е тестирование ПО — это фикция (я говорю о реальном 
ПО, а не о программах из наших примеров} и единственное, что мы 
можем сделать как тестировщики, — это профессионально, творчески 
и добросовестно спланировать и провести наше тестирование. Про- 
сочившиеся баги — это неизбежное зло, но свести его к мини- 
муму — в наших руках. 


ВТОРАЯ КОНЦЕПЦИЯ: критерий эффективности тестирования — 
это количество багов, найденных до релиза. 


РАЗОБЛАЧЕНИЕВТОРОЙ КОНЦЕПЦИИ 


Допустим, открывается новый обувной магазин на Кузнецком, 
чтобы все развитые личности ходили в лаковых ботинках. 


Скажите, имеет ли значение для развитой личности, сколько де- 
нег и сил было потрачено на покупку и ремонт помещения? От- 
вет отрицательный: единственное, что ее интересует, — это 
сходная цена и качество обуви. Так и в нашем интернет-магазин- 
ном деле: пользователю все равно (и это правильно), сколько 
вы не спали ночей, сколько вы нашли багов и скольких деву- 
шек оставили без романтического ужина. Пользователю нуж- 
но, чтобы наш онлайн-магазин работал качественно. Точка. 


Идем дальше. 


Идея о статистике для пострелизных багов 


Итогом разработки ПО является передача этого ПО пользовате- 
лю, называемая "релиз" (те/еаѕе). 


Допустим, что перед первым релизом нашли 50 багов, а перед 
вторым — 200. Казалось бы, во втором случае тестирование про- 
шло более успешно. Но в реальности вполне может быть, что по- 
сле первого релиза пользователи найдут 2 бага, а после второго — 
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22 бага. Тестирование какого релиза было более эффективным? 
Очевидно, что первого, так как первый релиз дал возможность 
пользователям познакомиться только с двумя багами в отличие 
от второго релиза — с 22 багами. 


Кроме того, результаты тех же самых усилий, но приложен- 
ных для тестирования разных функциональностей могут 
серьезно различаться. Это происходит потому, что предмет тес- 
тирования, т.е. некая часть нашего ПО, подвергнутая тестирова- 
нию, каждый раз уникален. Уникален качеством кода, сложно- 
стью и трудоемкостью тестирования и прочими вещами. 


Кстати, 
один из критериев качества кода — это количество багов на 
1000 строк кода. 


Почему же так популярно представление количества багов ДО 
релиза в качестве цели и критерия эффективности тестирования? 


Поставьте себя на место менеджера отдела тестирования. Ему 
нужны просто количественные данные, чтобы показать своим 
менеджерам, что в коде данного релиза под его чутким руковод- 
ством тестировщики нашли столько-то багов. 


Еще одной причиной любви к количеству багов, найденных до 
релиза, может быть элементарное незнание основ тестирования 
(в которые мы, кстати, незаметно, но верно вгрызаемся). 


Итак, 


количество багов, найденных до релиза, ничего не говорит об 
эффективности тестирования. 


Баги, найденные после релиза, — вот что нас угнетает и 
преследует в бессонные лунные ночи. 


Кстати, если уж мы заговорили о статистике и цифрах, давайте 
скажем пару слов о том, как мы используем данные о таких вот 
пострелизных багах. 


Сначала определимся с тем, что баги бывают разных приори- 
тетов, которые отражают важность бага. Скажем, если у 
машины на дороге отваливается колесо, это Ш (баг высшего 
приоритета). Таких приоритетов обычно 4. Соответственно к 
ПА относятся самые незначительные баги (как небольшая цара- 
пина на боку автомобиля). 
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Итак, после каждого релиза данные о багах, найденных после 
релиза, классифицируются по заданным критериям и анали- 
зируются на предмет нахождения слабого звена в процессе 
разработки ПО. 


Критериями могут быть приоритет, функциональность, имя тес- 
тировщика и др. 


Пример 
После очередного релиза мы совместили статистику по критериям 


• функциональность и 
• приоритет, 


Регистрация | Поиск |Корзина | Оплата 


Функциональность 


Приоритет 


При попытке найти "рекордсменов" можно увидеть, что совсем груст- 
ная картина сложилась с оплатой (7 П1). 


Еще один пример, чтобы показать, какова польза от сопоставле- 
ния статистики от релиза к релизу и что нужно делать с теми, кто 
эту статистику портит. 


Пример 

Допустим, что у нас постоянно возникают проблемы с "Оплатой". После 
каждого из релизов в ней находят по несколько П1 и П2, т.е. появился 
устойчивый паттерн (раїйет — шаблон, тенденция) проблемы. Все спе- 
ки по оплате составлены продюсером, весь проблемный код написан 
программистом и проверен тестировщиком. Первое, что приходит в 
голову, — во всем виноват тестировщик. Но если проявить человеко- 
любие и талант руководителя, то может всплыть: 


• продюсер пишет совершенно мерзопакостные спеки; 

• тестировщик в свое время женился на невесте программиста, 
всячески избегает его; 

• оба они ненавидят продюсера, так как тот является зятем прези- 
дента компании. 
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Дальнейшее расследование показывает, что 


• продюсер не имеет ни бэкграунда, ни документации, чтобы 
понять все нюансы "Оплаты", связанные с электронными пла- 
тежами; 

• программист и тестировщик зарекомендовали себя как блестя- 
щие профессионалы на всех проектах, когда их пути не пересе- 
кались. 


А вы говорите "Элементарно, Ватсон"! Вот оно, истинное рас- 
следование! А то обидели бы бедного тестировщика, а в следую- 
щий раз все повторилось бы. 


Заметьте, что ко всему этому мы пришли, начав с анализа стати- 
стики, а это уже не тестирование, а ОА (ОиаШу Аѕѕигапсе — бук- 
вально "обеспечение качества", произносится "кью-эй"). 


Тестирование и ОА (ФиаШу Аѕѕигапсе) 


Рассмотрим базовую концепцию ОЛ и то, как оно соотносится с 
тестированием. 


Пример 


Лежит дома на диване некий член правления некого крупного банка. 
Весь такой благообразный, вальяжный и циничный, как будто он всегда 
был и будет членом правления. Тишину разрывает звонок телефона, 
холеные пальцы снимают трубку, и в сознание проникает голос быв- 
шей жены, которую он бросил 11 лет назад, сразу после своей первой 
сделки с продажей вагона ворованных противогазов. Бывшая жена го- 
ворит, мол, твой сын прогуливает уроки математики и рисования, це- 
Луется в подъезде с соседской Дашкой, которая на два года старше 
него, перестал гулять с собакой и начал курить. В общем, дела плохие. 
Так вот, 


ОА-подход — это изначально остаться с женой и воспитывать сына. 


Тестирование — это когда после звонка оставленной жены экс- 
хузбенд запирает сынишку в своей загородной резиденции, ограничи- 
вает его духовную и половую жизнь полным собранием произведений 
Ги Де Мопассана, выписывает из Англии учителей, устраивает педсо- 
вет и говорит, что у них есть З года, чтобы неуч, тунеядец, курильщик и 
сексоман стал образованным, трудолюбивым и здоровым членом ци- 
вилизованного общества. 


Таким образом, 


ОА — это забота о качестве в виде превентирования появле- 
ния багов, тестирование — это забота о качестве в виде обна- 
ружения багов до того, как их найдут пользователи. 
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Общее в ОА и тестировании заключается в том, что они призваны 
улучшить ПО, различие между ними — в том, что 


• ОА призвано улучшить ПО через улучшение процесса 
разработки ПО; 
• тестирование — через обнаружение багов. 


Несмотря на то что большая часть книги посвящена тестирова- 
нию, многие вещи будут рассмотрены именно с точки зрения 
ОиаШу Аѕѕиғапсе. 


В реальных компаниях инженер, который занимается улучшени- 
ем процесса разработки ПО, должен иметь очень серьезную под- 
держку в менеджменте компании, чтобы быть в состоянии про- 
вести свои идеи качества в жизнь. Без такой поддержки никакого 
прока от инженера по качеству не будет, каким бы гениальным 
специалистом он ни был. 


Кстати, западные компании часто нанимают аудиторов для проверки 
внутренних процессов. Если ваша компания решит нанять аудитора, 
который стоит больших денег, то постарайтесь не заключать договор с 
крупной аудиторской компанией, которая элементарно может вам 
подсунуть ничего не понимающего в деле товарища с кожаным порт- 
фелем, а лучше заключите контракт с конкретным специалистом по ка- 
честву, проведя ряд интервью и найдя того, кто действительно разби- 
рается в своем деле. Запомните, что аудитом кормятся много парази- 
тов, которые напишут вам бессмысленные, но солидно презентован- 
ные заключения и рекомендации,, которые вам никогда не пригодятся, 
и впоследствии вы будете долго ломать голову, пытаясь понять, ЗА ЧТО 
же вы все-таки заплатили. 


Кстати, хотя инженер по качеству (ОА Епдтее) и тестировщик (Теѕї 
Епдтее) — это разные профессии, тестировщиков часто называют 
инженерами по качеству. 


Пара мыслей вдогонку к сказанному. 


Пример с батькой и сынкой позволяет нам понять и ощутить со 
всей болью русской интеллигенции, что тестировщики имеют 
Дело с ПО, переданным им программистами уже в кривом и 
порочном состоянии. С этим соприкасается правильная, сладкая 
и полезная идея, что за качество не могут быть ответственны 
только тестировщики. 


Качество (как и его отсутствие) — это результат 


• деяний всех участников процесса разработки ПО, а также 
• отлаженности и настроек самого процесса. 
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Краткое подведение итогов 


1. 


2. 


Цель тестирования — это нахождение багов до того, как их най 
дут пользователи. 

Нехватка ресурсов не позволит стопроцентно протестировать 
сколько-нибудь сложное ПО. 

Не имеет никакого значения, сколько багов было найдено до 
релиза. 

Статистика багов, найденных после релиза, и ее последующий 
анализ могут помочь идентифицировать проблемные участки 
процесса разработки ПО. Сопоставление статистики от релиза к 
релизу дает, как правило, устойчивый паттерн проблемы, если 
таковая существует. 

ОА направлено на превентирование багов, тестирование — на 
поиск багов. 

Тестировщики одни не могут обеспечить качество ПО. Обеспе- 
чение качества — это задача всех участников процесса раз- 
работки ПО. Важными факторами, влияющими на качество, 
являются отлаженность и настройки самого процесса разработки 
ПО. 


Вопросы и задания для самопроверки 


1. 


У вас есть 5 функциональностей, и отведенного времени не хва- 
тит, чтобы тщательно протестировать их все. На основании чего 
вы расставите приоритеты в тестировании? Подсказка: помните 
о счастье пользователя. 

Петров нашел 50 багов до релиза, но пропустил 5 багов, которые 
были найдены пользователем. Сидоров нашел 12 багов до 
релиза, не пропустив ни одного. Кому дать премию? 

Как должен поступить менеджер, чтобы решить вопрос с про- 
блемой оплаты? 

Придумайте аналогию, демонстрирующую разницу между ОА и 
тестированием. 


ИСКУССТВО СОЗДАНИЯ 
ТЕСТ-КЕЙСОВ 


• ЧТО ТАКОЕ ТЕСТ-КЕЙС 

•  СТРУКТУРАТЕСТ- КЕЙСА 

• ИСХОД ИСПОЛНЕНИЯ ТЕСТ-КЕЙСА • 
ПОЛЕЗНЫЕ АТРИБУТЫ ТЕСТ-КЕЙСА 

• ТЕСТ-КЕЙСЫ, УПРАВЛЯЕМЫЕ ДАННЫМИ • 
ПОДДЕРЖИВАЕМОСТЬ ТЕСТ-КЕЙСА 


® СКОЛЬКО ОЖИДАЕМЫХ РЕЗУЛЬТАТОВ МОЖЕТ БЫТЬ 
В ОДНОМ ТЕСТ-КЕЙСЕ? 


• ПРОБЛЕМНЫЕ ТЕСТ-КЕЙСЫ 
• ТЕСТ-КОМПЛЕКТЫ 

• СОСТОЯНИЯ ТЕСТ-КЕЙСА 

• АНАПОСЛЕДОК Я СКАЖУ 


М исполняем тестирование, т.е. непосредственно "рвем на 
куски" ПО, руководствуясь нашей профессиональной до- 
кументацией — тест-кейсами (1651 саѕе). Поговорим о формаль- 
ной стороне эффективного тест-кейса и коснемся объединений 
тест-кейсов — тест-комплектов (1е51 5ийе). 


Что такое тест-кейс 
Допустим, что перед сборами на рыбалку мы составили следую- 
щий список: 


1. Удочка. 
2. Коробка с запасными поплавками и леской. 
3. Банка с червями. 
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— А зачем 
нам черви? 
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4. Стакан граненый. 
5. Бутылка "Абсолюта". 
6. Огурец соленый. 


Затем при деятельном участии жен, детей и котов мы наконец 
собрались в дорогу и перед выходом взяли список и проверили 
рюкзак на наличие каждого из 6 предметов. 


Так вот. 
Каждая из 6 строк списка — это и есть тест-кейс (1е51 саѕе). 
Сам список является тест-комплектом (їеѕі 5ийе). 


Процесс придумывания и написания каждой строки списка 
называется созданием тест-кейса (е5? саѕе зепегайоп). 


Процесс проверки рюкзака на наличие определенного пред- 
мета — исполнением тест-кейса (їеѕї саѕе ехесийоп). 


Теѕі саѕе можно перевести как "тестируемая ситуация" и как 
"оболочка для теста", оба перевода легитимны и представляют 
собой идеальный союз для понимания места и значения тест-кей- 
сов в этом жестоком мире. 


Главная и неотъемлемая часть тест-кейса — это ожидаемый 
результат, например "огурец соленый", т.е. тест-кейс может 
полностью состоять только из ожидаемого результата. 


Структура тест-кейса 


Проблема в том, что для нахождения бага (что является смыслом 
любого тестирования) кроме ожидаемого нам нужен и фактиче- 
ский результат. В случае с огурцом мы просто заглядываем в 
рюкзак и смотрим, на месте ли этот "фрукт". В случае же тести- 
рования ПО, как правило, необходима инструкция, как прийти к 
фактическому результату. 


Пример 

Допустим, тестировщику А. Боброву, который только что начал рабо- 
тать в нашем стартапе имуму.іеѕїѕһор.гѕ, дали для исполнения следую- 
щий тест-кейс: 


"Оплата может быть произведена картой ИБА". Сразу же 


возникает по крайней мере две проблемы: 
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• для исполнения тест-кейса нужна тестировочная карта /184, 
которой у него нет; 

• он незнает, как проверить, был ли действительно осуще- 
ствлен платеж, даже если бы у него была карта. 


Единственное, что более или менее понятно, — это процесс по- 
купки в интернет-магазине (найти товар, добавить в корзину и 
т.д.), что в данной ситуации помогает немного. Естественно, что 
никакого тестирования не будет, так как пробиться к фактиче- 
скому результату так же трудно, как доказать инспектору ГАИ, 
что брать взятки аморально. 


Пример 
Допустим, тестировщику А. Боброву, который только что начал рабо- 
тать в нашем стартапе илим!4е${5Пор.гз, дали для исполнения следующий 
тест-кейс: Шаги: 
Открой иим. таіп.іеѕіѕһор.гѕ 
Введи в поле "Имя пользователя": "їеѕіиѕег1" 
Введи в поле "Пароль": "ра$$иОга" 
Нажми кнопку "Войти" 
Введи в поле "Поиск": "Боок117" 
Нажми кнопку "Найти" 
Кликни линк "Добавить в корзину" 
Кликни линк "Корзина" 
Кликни линк "Оплатить" 
Выбери из меню "Вид карты": "МІЅА" 
Введи в поле "Номер карты": "9999-5148-2222-1277" 
Введи в поле "Действительна до": "12/07" 
Введи в поле "СИ/2": "778" 
Нажми кнопку "Завершить заказ" 
15. Запиши номер заказа 
16. Запроси базу данных: 
ѕеіесі гезий тот сс ігапѕасііоп иһеге іа = <номер заказа >; 


А А 
мо оо мофтмом№ м 


< А А 
һо № 


Ожидаемый результат: "10" 


Очевидно, что тест-кейс из последнего примера вполне может 
быть исполнен любым, кто знает, как напечатать "ра$$\/Ога". 


В последнем примере (который мы назовем тест-кейс с картой) к 
ожидаемому результату (ОР) добавились шаги (5ѓерѕ), которые 
должны привести нас к фактическому результату (ФР), необ- 
ходимому, чтобы узнать, есть баг или нет. Совокупность шагов 
называется процедурой (ргосейиге). 


Если провести аналогию, то 


• шаги — это ступеньки лестницы; 
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• ожидаемый результат — это некий предмет, который мы 
должны найти, если поднимемся по этим ступенькам; 

• фактический результат — это то, что мы реально нашли 
после того, как поднялись по этим ступенькам. 


Постановка мозгов 
Исходя из основной компьютерной концепции ввод/вывод (на языке 
оригинала — триИошриу: 


• шаги — это инструкция по вводу; 

• исполнение шагов — это ввод; 

• ожидаемый результат — это ожидаемый вывод; 

• фактический результат — это фактический вывод. 


Исполнение тест-кейса завершается сравнением вывода факти- 
ческого и вывода ожидаемого. 


Исход исполнения тест-кейса (ѓеѕї 
саЅе гезий) 


Каждый тест-кейс, исполнение которого завершено, дает нам од- 
но из двух: 


1. Положительный исход (РА55), если ФР равен ОР, 
либо 


2. Отрицательный исход (РАЈ), если ФР не равен ОР: най 
ден баг! 


Иногда возникает ситуация, когда мы заблокированы (151 саѕе 
ехесийоп 15 Ыоскеа), так как не можем пройти ВСЕ шаги тест- 
кейса. Например, мы не можем продвинуться дальше, если кноп- 
ки "Завершить заказ" из шага 14 не существует на соответствую- 
щей веб-странице. В таком случае мы рапортуем баг (в данном 
случае баг об отсутствии кнопки "Завершить заказ") и отклады- 
ваем исполнение тест-кейса до устранения бага. 


Полезные атрибуты тест-кейса 
УНИКАЛЬНЫЙ /0 (Ипбие 10) 


Это необходимая вещь. Тест-кейс без > — это то же самое, что 
квартира без адреса или швейцарские часы без номера. /2 должен 
быть уникальным в пределах не только документа, содержащего 
тест-кейс (об этом документе позже), но и всего департамента 
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качества. Рациональное обоснование: со временем появится не- 
обходимость вести статистику по тест-кейсам, обновлять, удалять 
или переносить в другой документ некоторые из них, прикрывать 
спину И т.д. 


ПРИОРИТЕТ ТЕСТ-КЕЙСА (Тез! Саѕе Риотйу) 


Это важность тест-кейса. Важность отражается по шкале от 1 доп, 
где 1 — это высший приоритет, а п — это низший приоритет. 
Думаю, что рационально делать и = 4. 


Допустим, тест-кейс, проверяющий, работает ли кнопка "Купить", 
будет 1-го приоритета, а тест-кейс, проверяющий цвет шрифта 
линка "Гостевая книга", будет 4-го приоритета. Концептуально, 
думаю, понятно. 


Зачем это делается? Допустим, у нас есть два тест-кейса: один 1- 
го приоритета и другой — 3-го приоритета, оба тестируют некую 
функциональность А, и есть время для исполнения только одного 
из них. Естественно, что мы выберем тест-кейс 1-го приоритета. 
Приоритезация тест-кейсов особо полезна при регрессивном 
тестировании, о котором мы не раз будем говорить. 


Вопрос: Как присваиваются приоритеты? 

Ответ: Конечно, все зависит от компании, но, как правило, автор 
тест-кейса просто решает, насколько жизненно важна, опреде- 
ляюща и критична вещь, проверяемая данным тест-кейсом. 


ИДЕЯ (ІРЕА) 


Это описание конкретной вещи, проверяемой тест-кейсом (в даль- 
нейшем эту конкретную вещь мы также будем называть "идея 
тест-кейса"). 


Пример 

В тест-кейсе с картой ожидаемым результатом является значение "10" 
в колонке гезий строки с нашей транзакцией. Поймет ли, ЧТО мы тес- 
тируем, человек, который не знает, что программисты имуму.іеѕїѕћор.г= 
обозначают первую цифру результата транзакции индексом кредитной 
карты (где "1" — это МІЅА, "2" — МазегСага, "3" — Ѕүуџїсһ), а вторую — 
флагом успеха (где "О" — это успех, а "1" — ошибка) и соответственно 
"10" означает, что транзакция с картой МІЅА была успешной? 


Дело в том, что "непосвященным" может стать даже автор тест- 
кейса, скажем, через месяц после написания, так как все в мире 
тленно и забываемо (кроме, конечно, первой школьной любви 
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Ани В.)- Поэтому в начале тест-кейса следует написать на чело- 
веческом языке: "Оплата может быть произведена картой И/5А", 
чтобы любой, кто возьмет этот тест-кейс в руки, не ломал голову, 
а сразу понял, что проверяется этим тест-кейсом. 


ПОДГОТОВИТЕЛЬНАЯ ЧАСТЬ (5ЕТОРаиа АРПІТІОМАГ ІМЕО) 


Кулинарный рецепт, как правило, включает две части: 


1. Список ингредиентов и количество/вес каждого из них; 
2. Инструкция по тому, как жарить, парить и варить несчаст- 
ных из пункта 1. 


Первая часть рецепта нужна для того, чтобы повар мог знать 
заранее, видеть в одном месте все необходимые составляющие 
блюда и иметь их под рукой, когда "настанет день и час". В 
общем выделение подготовительной части удобно, логично и 
практично. 


В подготовительную часть тест-кейса могут включаться: 


• данные о существующем эккаунте пользователя ([егасу изег 
ассоипі) или инструкции по созданию нового эккаунта (пеу 
иѕег ассоипі); 

. другие данные, используемые в тест-кейсе, например атри- 
буты используемой кредитной карты; 

• запросы к базе данных (5ОГ, диегіеѕ), используемые в тест- 
кейсе; 

• комментарии в помощь тестировщику, например о ню- 
ансах, которые могут встретиться при исполнении тест- 
кейса; 

. другие вещи, облегчающие исполнение и поддержку тест- 
кейса (о поддержке мы еще поговорим). 


ИСТОРИЯ РЕДАКТИРОВАНИЯ (Кеибюп Ніѕіоғу) 
Очень полезная вещь. 


Пример 
Допустим, у Макса Крылова живет попугай-жако Вася. Макс учит его 
хорошим фразам: 


— "Вася хороший"; 

— "Атісиѕ Раю, ѕеа тадіѕ атіса Мегїаѕ" ("Платон мне друг, но истина 
дороже"); 

— "Веайе$ Югеме!" («ВИА "Битлз" будет вечно жить в наших сердцах»). 
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Приходит друг Лежа и, пока Макс на правах радушного хозяина несется 
к ларькам станции метро "Юго-Западная" и обратно, учит альтерна- 
тивной мудрости честно впитывающего знания Васю: 


— "Все козлы"; 

—"Ѕітіа диатит ѕітіііѕ іигріѕѕіта Беѕіа побіѕ!" ("Как похожа на нас 
мерзейшая тварь — обезьяна!"); 

— "Моуе БйсИ, деЁ ои те мау" ("Уйди с дороги, противная"). 


В итоге после возвращения домой Макса встречает не добрый, милый 
попугайчик, а негативно настроенная машина, и вечером ему (Максу) 
придется доказывать своей жене, что это не он, а подлец Леха изменил 
лексикон бедолаги Василия. 


Для того чтобы иметь сведения о рождении и истории развития 
каждого тест-кейса, мы ведем лаконичный журнал изменений, 
где отражаем: Кто? Что? Зачем? Когда? Почему? 


Атрибуты истории редактирования: 


• Стеше4 оп <ааіе> Бу <пате> — Тест-кейс создан <дата> 
<кем>; 

‚ Мойјеа оп <ааіе> Бу <пате> — Тест-кейс изменен <да- 
та> <кем>; 

• Сһапве — Что, зачем и почему было изменено. В наших 
примерах мы не печатаем само слово "сраизе”, а просто 
заполняем значение этого атрибута в поле справа от 
"Стеше4 оп..." или "Моатеа оп...". 


Давайте создадим тест-кейс с картой, используя только что полу- 
ченные знания по полезным атрибутам тест-кейса: 


ТС Ір/Ргіогіќу ССРО0001 


ЕА: Оплата может быть произведена картой УІЅА ЅЕТОР апа 
АОРТТЮМАГ, ІЧЕО: 

Эккаунт: іеѕіџѕег 1/ра55%№Ога Наименование товара: Боок117 Данные 
карты: 

Номер: 9999-5148-2222-1277 

Окончание действия: 12/07 

СУУ?: 778 

ЗОТГЛТ: зв[есё геѕші гот сс ігапѕасіоп ућеге 14 = <номер заказа>; 


Кеуіѕіоп Ногу 


Сгеаќеа оп: 11/17/2003 Бу О.Тарасов 
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Ехесийоп рагі 
РВОСЕБОВЕ ЕХРЕСТЕО ВЕЗОГТ 


1. Открой ууугү.таїп..іеѕіѕһор.гѕ > "10" 
2. Введи имя пользователя. 
3. Введи пароль. 
4. Нажми кнопку "Войти". 
5. Введи наименование товара в поле 
поиска. 
6. Нажми кнопку "Найти". 
7. Кликни линк "Добавить в корзину". 
8. Кликни линк "Корзина". 
9. Кликни линк "Оплатить". 
10. Выбери вид карты. 
11. Введи номер карты. 
12. Введи срок окончания действия. 
13. Введи СУУ2. 
14. Нажми кнопку "Завершить заказ". 
15. Запиши номер заказа 
16. Запроси базу данных с $011 
и запиши результат 


Идем дальше. 


Тест-кейсы, управляемые данными 


Основной плюс нового тест-кейса с картой заключается в том, что 


нам не нужно вносить изменения в ШАГИ, чтобы протестиро- 
вать по тому же сценарию другие карты. Единственное, что 
нам нужно, — это модифицировать исходные ДАННЫЕ. 


Таким образом, если кроме //Ѕ4 нам нужно протестировать по 
тому же сценарию еще две карты, то мы 


• делаем сору один раз; 

• разѕіе два раза; 

• в каждом из новых тест-кейсов переписываем только пять 
подчеркнутых значений, проживающих в шапке тест-кейса и 
секции ожидаемого результата (меняем и /О тест-кейса — ТС 1, 
который, как мы помним, должен быть всегда уникальным): 


МБА 
9999-5148-2222-1277 
12/07 

778 

10 
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Такой вид тест-кейса называется Фаѓа-йгіуеп (буквально "управ- 
ляемый данными"), т.е. когда данные и инструкции по их при- 
менению не смешаны, а разделены и слинкованы. 


Поддерживаемость тест-кейса 


Новый тест-кейс с картой хорош. Все при нем — и Яйѓа-дгіуеп, и 
удобочитаемый формат, и полезные атрибуты. Проблема в том, 
что веб-сайт, а особенно его часть, именующаяся интерфейсом 
пользователя {Изег [те асе или просто ИР "ю-ай"), очень часто 
меняется. 


Пример 


Кнопка "Войти" из шага 4 легко может быть переименована во "Вход". 
Следовательно, если у нас есть З тест-кейса, то нужно внести З измене- 
ния. А что, если у нас 500 тест-кейсов, где упоминается кнопка "Войти", 
и эти тест-кейсы разбросаны по разным документам, как мои одно- 
классники по свету? Вносить 500 изменений? Скажете: "Ерунда, можно 
догадаться". Но таких маленьких изменений будут десятки!! И посте- 
пенно ваши тест-кейсы будут либо хиреть без поддержки, либо потреб- 
лять на поддержку уйму времени. 


Пример 

А что, если не имя кнопки, а сам путь, по которому вы добираетесь до 
фактического результата, претерпел изменения? Например, шаги 7 и 9 
станет разделять не линк "Корзина", а еще несколько дополнительных 
линков и кнопок, появившихся в новой версии или! 4е5Пор.гз. 


В общем проблема понятна. И имя ее — таіпіаіпађіїйу (поддер- 
живаемость), т.е. насколько легко и просто можно изменить 
тест-кейс при изменениях в ПО. Не думать о поддерживаемо- 
сти тест-кейсов — значит не думать о завтрашнем дне, что, не- 
смотря на полезность для духовной жизни, все-таки плохо для 
бизнеса. 


Если мы разобъем шаги нашего нового тест-кейса с картой на ло- 
гические модули, получим: 


1. Вход в систему (логин — Іо іп). 
2. Поиск товара. 

3. Добавление товара в корзину. 

4. Оплата. 

5. Фиксация номера заказа. 

6. Запрос базы данных. 
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Почему бы нам не выбросить из тест-кейса детали по следующим 
позициям? 


1. Вход в систему 


В общем-то можно догадаться, куда ввести имя пользователя, 
куда пароль и на какую кнопку нажать, тем более что в данном 
случае мы не тестируем процесс логина, это было или будет сде- 
лано при исполнении соответствующего тест-кейса, сейчас мы 
просто грубо и бесцеремонно используем логин, легкомысленно 
надеясь, подобно покупателю российского автопрома, что все 
будет чики-пики. 


2. Поиск товара 


Все из предыдущего пункта применимо и здесь. Кроме того, до- 
пустим, что Боок117 была удалена из нашей базы данных подлы- 
ми завистниками и подхалимами. Что же нам — в отчаянии рвать 
на себе волосы и кричать, что мы заблокированы? Нет, мы просто 
превентируем такую ситуацию тем, что не будем давать имени 
конкретного товара. Что найдется, то найдется (так как то, что 
найдется, в данном случае значения не имеет). 


3. Добавление товара в корзину 


Концепция из "1. Вход в систему" применима и здесь. 


4. Оплата 
Концепция из "1. Вход в систему" применима и здесь. 


О'к, с оплатой я, пожалуй, немного переборщил — не факт, что 
будет абсолютно очевидно, как провести ее, и шаги все же потре- 
буются. 


Здесь появляется другая загвоздка: если мы производим оплату в 
сотнях тест-кейсов, т.е. сотни раз включаем в тест-кейс те же 
семь шагов (8—14 включительно), то при изменении даже в од- 
ном из этих шагов нам придется переписывать эти сотни тест- 
кейсов... 


Не проще ли вынести шаги, повторяющиеся от тест-кейса к 
тест-кейсу, во внешний документ и вместо них включить ° 
тест-кейс лишь один шаг-ссылку «Произведи ОПЛАТУ 
КАРТОЙ из секции "ЅЕТОР апа АРОГПОМАГ ІМЕО"»? Поступив 
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таким образом, мы сэкономим громадное количество часов рабо- 
чего времени, так как при необходимости менять шаги нужно 
будет только в одном месте! 


Кстати, "оплата картой" — это линк к страничке в локальной сети с со- 
ответствующей инструкцией, называемой, например, "Как произвести 
оплату кредитной картой". 


Кстати, хорошей идеей является создание в локальной сети вашей 
компании мини-веб-сайта департамента качества, где наряду с веб- 
страничками с 


• контактной информацией работников департамента, 
• пинками к файлам с тест-комплектами, 
• другой полезной информацией 


расположится и внутреннее Пособие для тестировщиков (ОА Кпоиі- 
еаде Ваѕе), где кроме прочего будут задокументированы повторяю- 
щиеся сценарии. 


Теперь обобщим уже известные нам мероприятия по улучшению 
поддерживаемости тест-кейса: 


1. Сделать тест-кейс даѓа-гіуеп. 

2. Не описывать шаги по явно очевидным сценариям (напри- 
мер, логин). 

3. Не давать конкретных деталей, если они не играют роли 
при исполнении тест-кейса (например, имя товара). 

4. Вынести во внешний документ повторяющиеся сценарии 
(например, семь шагов оплаты). 


Ну, за поддерживаемость! 


ІЮЕА: Оплата может быть произведена картой УІЅА ЅЕТОР апа 
АРОІТІОМАТ ІМЕО: 
Эккаунт: ѓеѕіџѕег1/ра58$%Ога Данные карты: 
Номер: 9999-5 148-2222-1277 
Окончание действия: 12/07 

СУҮ2: 778 ЗО: ѕеЈесі теѕи от сс ігапѕасйоп мћеге 14 
= <номер заказа>; 


Кеуіѕіоп Ногу 


Сгеаќей оп: 11/17/2003 Бу О.Тарасов 


Моде оп: 11/26/2003 Бу И. Новикова | Шаги были упрощены, чтобы 
сделать тест-кейс более удобным 
для поддержки 
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Ехесийоп рагі 


РВОСЕБОВЕ ЕХРЕСТЕО ВЕЗОГТ 


1. Открой угугүу.таіп.ќеѕіѕһор.гѕ > "10" 


2. Войди в систему. 

3. Найди любой товар. 

4. Добавь товар в корзину. 

5. Произведи оплату картой из секции 
ЅЕТОР апа АРОІТІОМАГ [МЕО 

6. Запиши номер заказа 


7. Запроси базу данных с 5011 
И запи и ре дьта 
ЕЕВС ЕЕ 


Идем дальше. 


Сколько ожидаемых результатов 
может быть в одном тест-кейсе? 


Тест-кейсом проверятся только одна конкретная вещь, и в иде- 
альном варианте для проверки этой вещи достаточно предусмот- 
реть в тест-кейсе только один ОР, и если бы я был теоретиком, а 
не практиком тестирования, то сказал бы, что ни в коем случае 
нельзя включать в тест-кейс более одного ОР. 


Вотвам случай из практики 


Допустим, что в соответствии с пунктом 12.6 документа "Дизайн кода 
для спека #6522" признаком того, что оплата была успешно прове- 
дена картой МІЅА, будет одновременное наличие не одного, а двух 
условий: 


1. Значение "10" в соответствующей колонке соответствующей строки в 
базе данных. 

2. Уменьшение баланса на счете с картой МІЅА на сумму, равную сумме 
оплаты. 


То есть получается, что для тестирования одной вещи ("Оплата 
может быть произведена картой И15А") нужно проверить соответ- 
ствие жизненной реальности двум ожидаемым результатам. 


У нас есть два пути: 


1. Разложить идею тест-кейса на две идеи и создать два тест-кейса. 
2. Оставить идею тест-кейса неприкосновенной и включить в один 
тест-кейс два ОР, т.е. у нас складывается ситуация, 
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когда исполнение тест-кейса будет иметь положительный 
исход, только если ОБА фактических результата совпадут 
с соответствующими им ожидаемыми результатами. 


Вот как будет выглядеть визуально путь 2: 


ІЮЕА: Оплата может быть произведена картой УІЅА ЅЕТОР апа 
АРОІТІОМАТ ТУЕО: 
Эккаунт: ѓеѕіџѕег1/ра585%Ога Данные карты: 
Номер: 9999-5148-2222-1277 
Окончание действия: 12/07 

СУҮ2: 778 ЗО: заесЕ тезиК от сс ігапѕасйоп \Теге 14 
= <номер заказа>; Баланс счета карты можно посмотреть здесь: 
улуу\/.таш.4е$5Нор.т5/1277/Ба1апсе.бла 


Сгеаќеа оп: 11/17/2003 Бу О.Тарасов 


Моаеа оп: 11/26/2003 Бу И. Новикова |Шаги были упрощены, чтобы 
сделать тест-кейс более удобным 
для поддержки 


Моде оп: 01/17/2003 Бу И. Новикова |Изменение шагов и второй 
ожидаемый результат с целью 
удостоверения в снятии денег со счета 


Ехесийоп рагі 
РВОСЕБОВЕ ЕХРЕСТЕО ВЕЗОГТ 


. Запиши баланс счета карты $> "10" 
Открой ууугү.га1п.іеѕіѕһор.гѕ 
Войди в систему. 
Найди любой товар. 
Добавь товар в корзину. 
. Произведи оплату картой из секции 
ЅЕТОР апа АРОІТОМАГ ІМЕО 
(!!! запиши полную сумму заказа: 
). 
7. Запиши номер заказа 
8; Запроси базу данных с $011. 


9. Запиши баланс счета карты > Шаг 1-Шаг 6 


Как будет проходить исполнение этого тест-кейса? 
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Прошли восемь шагов. Остановились. Проверили. Затем 
прошли девятый шаг. Остановились. Проверили. 


Исход исполнения этого тест-кейса будет считаться положитель- 
ным только при одновременной истинности двух условий: 


1. ФР после исполнения шага 8 = "10" и 
2. ФР после исполнения шага 9 = Шаг 1 - Шаг 6 (т.е. значе- 
ние из Шага 1 минус значение из Шага 6). 


В теории лучше было бы разбить нашу идею тест-кейса на две 
части и создать два отдельных тест-кейса: 


1. РЕА: "Правильное значение вставляется в базу данных 
при использовании 7/5 А". 
2. ІРЕА: "Верная сумма списывается с баланса карты". 


И если есть возможность, то ЛУЧШЕ сделать именно два тест- 
кейса, НО на практике во многих случаях имеет смысл включить 
в тест-кейс 2 или больше ОР, так как: 


• у вас может просто не быть времени на написание, испол- 
нение и поддержку двух тест-кейсов*; 

• сэкономленное время можно потратить на написание, ис- 
полнение и поддержку тест-кейса, которым мы бы прове- 
рили другую вещь**. 

Если у нас есть один случай, когда можно совместить два ОР, то напи- 
сание, исполнение и поддержка двух тест-кейсов не представляет труда. 
А что, еслиу нас появляются сотни дополнительных тест-кейсов?.. 

В результате такой экономии мы с течением времени создаем десятки 


новых тест-кейсов, которые помогают нам провести более тщательное 
тестирование. 


Я работал с тест-кейсами, включающими более одного ОР, в 
течение многих лет, проводя тестирование сложнейшего ПО, 
связанного с финансовыми транзакциями, и могу сказать, 
что 2 или больше ОР в одном тест-кейсе — это нормальная 
практика. 


Идем дальше. 


Во многих случаях, когда несколько ожидаемых результатов про- 
СЯТСЯ В ОДИН тест-кейс, нужно проверить 


• значение(-я) на веб-странице и 
• значение(-я) в базе данных, 


"е. нужна проверка снаружи и изнутри или на гоп епа и Баск епа. 
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Постановка мозгов 


Егопі епа (читается как "фронт-энд") — это непосредственный интер- 
фейс пользователя, т.е. текст, картинки, кнопки, линки и прочие вещи, 
которые пользователь видите окне веб-браузера или е-мейл клиента. 


Васк епа (читается как "бэк-энд") — это ПО и данные, находящиеся за 
фасадом фронт-энда: НТМЁ-код веб-страницы, веб-сервер, код при- 
ложения, база данных и т.д. 


В последнем примере мы непосредственно "разговаривали" 


е. фронт-энд ом — в шаге 5, когда добавляли товар в корзину; 
. с бэк-эндом — в шаге 8, когда запрашивали базу данных. 


Проблемные тест-кейсы 


Теперь посмотрим, какие недостатки вы должны выжигать из 
своих тест-кейсов каленым железом. 


1. Зависимость тест-кейсов друг от друга. 
2. Нечеткая формулировка шагов. 
3. Нечеткая формулировка идеи и/или ожидаемого результата. 


1. ЗАВИСИМОСТЬ ТЕСТ-КЕЙСОВ ДРУГ ОТ ДРУГА 


Зависимость — это антоним независимости. Независимость тест- 
кейса выражается в том, что он не связан с другими тест-кейсами. 


Пример 
Тест-кейс 1: 
Шаги: 


1. Зайти в комнату. 
2. Подойти к стулу. 
3. Открыть правый внешний карман рюкзака. 


4. Засунуть руку в правый внешний карман рюкзака. 
Ожидаемый результат: Граненый стакан. 


Тест-кейс 2: 


Шаги: 

1. Зайти в комнату. 

2. Подойти к стулу. 

3. Открыть левый внешний карман рюкзака. 

4. Засунуть руку в левый внешний карман рюкзака. 
Ожидаемый результат: Огурец. 


Как видно, шаги 1 и 2 сейчас одинаковы и всегда будет искуше- 
ние улучшить то, что и так хорошо. 
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Пример 
Тест-кейс 1: 
Шаги: 
1. Зайти в комнату. 


2. Подойти к стулу. 
3. Открыть правый внешний карман рюкзака. 


4. Засунуть руку в правый внешний карман рюкзака. 
Ожидаемый результат: Граненый стакан. 


Тест-кейс 2: 
Шаги: 
1. Смотри шаги 1 и 2 из тест-кейса 1. 
2. Открыть левый внешний карман рюкзака. 
З. Засунуть руку в левый внешний карман рюкзака. 


Ожидаемый результат: Огурец. 


Так вот, таких вещей (имеется в виду шаг 1 тест-кейса 2) нужно 
избегать, так как: 


• тест-кейс 1 может быть удален из-за ненадобности ИЛИ 

• шаги по тестированию наличия стакана (в тест-кейсе 1) 
могут быть изменены (например, стакан лежит в другом 
рюкзаке, который находится на кухне). 


В обоих случаях будет непонятно, как исполнить тест-кейс ЭА так 
как 


• унас или нет шагов 1 и 2 из тест-кейса 1, или 
• они стали неправильными (с субъективной точки зрения 
тест-кейса 2). 


Другим распространенным случаем является допущение, что ПО 
или база данных уже приведены к нужному состоянию, так как 
были исполнены предыдущие тест-кейсы. 


Пример 
В тест-кейсе Х мы создаем транзакцию покупки книги. В тест-кейсе Ү 
мы, допуская, что тест-кейс Х был успешно исполнен, проверяем 
атрибут успешности транзакции покупки книги, не создавая саму транз- 
акцию ("Зачем напрягаться, когда она уже создана?"). В итоге мо- 
жет произойти ситуация, когда транзакция покупки книги не создана, 
так как 
• тест-кейс Х был удален; 
• тест-кейс Х был модифицирован так, что он создает транзакцию 
другого типа; 
• тест-кейс Х не создал транзакции по объективной причине (на- 
пример, не работал соответствующий код). 
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Как результат, во всех трех случаях мы не можем исполнить тест- 
кейс У, так как данных, на которые он опирается, просто не суще- 
ствует. 


Таким образом, хороший тест-кейс характеризуют: 


• отсутствие ссылок на другие тест-кейсы; 
• независимость от "следов", оставленных другими тест- 
кейсами в нашем ПО или базе данных. 


Следовательно, если у нас в документе А есть 10 тест-кейсов: 
тест-кейс 1, тест-кейс 2, ..., тест-кейс 10, то доказательством неза- 
висимости каждого из тест-кейсов будет тот факт, что их без 
ущерба для тестирования можно всегда исполнять в любом 
порядке, например, тест-кейс 10, затем тест-кейс 2, затем тест- 
кейс 6 ит.д. Принцип, думаю, понятен. 


Согласен, что повторение шагов или подг отовительной части тест- 
кейса кажется порой тупым занятием, но все-таки преимущества 
независимого тест-кейса перекрывают напряг операции скопиро- 
вал вставил. 


2. НЕЧЕТКАЯ ФОРМУЛИРОВКА ШАГОВ 


Пример 
"Пойди туда, не знаю куда". 


На шаги тест-кейса можно смотреть, как на инструкцию "Как 
пройти" (или "Как проехать"). 


Пример 

Если американцу, который в Москве первый раз, сказать (с видом 
москвича в пятом колене), что Красная площадь находится "за ГУМом", 
то он бессмысленно потратит много времени в поисках "загума" в путе- 
водителе. Если же черкнуть ему е-мейльчик с инструкцией: 


Выйди из "Националя". 

На улице поверни направо. 

Не поднимая глаз, пройди мимо первой стайки барышень. 
Не поднимая глаз, пройди мимо второй стайки барышень. 
Спустись налево в подземный переход. 

Следуй указателям на стенах с надписью "Красная площадь", 


ядом 


то он не только найдет Красную площадь и купит там прапорскую 
ушанку с гнутой кокардой, но и избежит обвинений в сексуальном хар- 
расменте, которые на его родине вещь очень даже серьезная. 
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Кстати, 


• шаги 1 — 5 включительно — это точные инструкции, а 

• шаг 6 — это отсылка к инструкциям, хранящимся в другом месте 
(помните, мы говорили о внутреннем Пособии для тестировщи-ков 
с шагами для повторяющихся сценариев?). 


Итак, перечисляющиеся в тест-кейсе шаги должны быть объ- 
ективно четкими и ясными. 


Нужно помнить, 


• то, что очевидно для вас сейчас, может стать совершен 

но непонятным через пару месяцев. 

Так, сокращенные шаги с нерасшифрованными аббревиа- 
турами и прочими веселыми прибамбасами, понятными 
вам сейчас, могут впоследствии стать китайской грамотой 
для вас самих, так что проще будет написать тест-кейс за- 
ново, чем пробираться через дебри неосмотрительно сде- 
ланных описаний; 


• Тест-кейс, который не может быть исполнен никем, 

кроме его автора, должен быть публично сожжен, рас 
терт в порошок и развеян по ветру. 
Обоснование простое: что, если автор тест-кейса заболеет, 
уйдет в отпуск, уйдет из компании или уйдет, извините, 
вообще? Любой тест-кейс должен создаваться с мыслью 
о коллеге, который однажды возьмет его в руки. 


Нужно избегать и другой крайности — когда шаги тест-кейса 
настолько детализируются, как будто он пишется для ученой 
обезьяны. Излишняя детализация ведет к усложнению поддер- 
живаемости тест-кейса, что было нами убедительно доказано 
минуту назад. 


В общем ищите золотую середину. 


3. НЕЧЕТКАЯ ФОРМУЛИРОВКА ИДЕИ ТЕСТ-КЕЙСА 
И/ИЛИ ОЖИДАЕМОГО РЕЗУЛЬТАТА 


Оба тезиса, о которых мы только что говорили: 
• ОТОМ, ЧТО МОЖНО забыть то, что сейчас ПОНЯТНО, И 
• писать тест-кейсы нужно не для себя, а для того парня — 


применимы и к идее и к ожидаемому результату. Нюансы ДЛЯ 
идеи тест-кейса и ожидаемого результата: 
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а. Не рекомендуется отсылка к внешнему документу. 
Когда мы говорили о выносе части шагов в Пособие для 
тестировщиков, то делали это в случаях многократно по- 
вторяющихся сценариев, встречающихся в разных тест- 
комплектах, с целью сделать наш тест-кейс более поддер- 
живаемым. С идеей же тест-кейса и ожидаемым результа- 
том — совсем другая история. 


Пример 
Подумайте, удобно ли будет исполнять тест-кейс, если в секции РЕА 
напечатано: 


«В этом тест-кейсе мы проверяем пункт 21.6 спека номер 34 "Сцена- 
рий добавления кредитной карточки к счету пользователя"» 


или в секции Ехресіеа Кезий!: 


"Проверь, что значение последнего шага равно значению пересечения 
значения шага 5 по оси Х и значению шага 23 по оси У из таблицы 17.0 
спека из секции РЕА"? 


б. Нужно помнить, что суть секции ДЕА — это ОБЪЯСНЕ 
НИЕ идеи тест-кейса. 


Пример 

Если секция ЛЕА пуста или же в ней скромно напечатано "10", то каж- 
дый исполняющий этот тест-кейс каждый раз будет тратить несколько 
минут своего времени и/или времени своего коллеги на выяснение того, 
что же проверяется этим тест-кейсом. 


в. Нужно помнить, что ожидаемый результат — это ин 
формация, на основании которой (вкупе с фактическим 
результатом) мы принимаем решение об исходе тест- 
кейса. Следовательно, точность и четкость в форму 
лировке ожидаемого результата играют наиважнейшую 
роль. 


Пример 


Ожидаемый результат гласит: "Проверь, что показана страница с 
ошибкой", и страница с ошибкой действительно показывается. Дело в 
том, что если показывается не та ошибка, которая положена по специ- 
фикации, то будет пропущен баг. Почему он будет пропущен? Пра- 
вильно: из-за неточной формулировки ожидаемого результата. 


Еще один пример плохого ожидаемого результата: 


"Все работает". 


Идем дальше. 
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Тест-комплекты 


С помощью каждого отдельно взятого тест-кейса проверяется 
какая-то одна вещь (развернуто сформулированная в секции 
ІРЕА). Каждый спек — это источник для множества идей тести- 
рования, и, таким образом, для проверки кода, написанного в со- 
ответствии со спеком, нам нужно множество тест-кейсов. 


Совокупность тест-кейсов (находящихся, как правило, в одном 
документе), которые проверяют 


какую-то определенную часть нашего интернет-проекта 
(например, "Оплату") и/или 

• определенный спек (например, спек номер 1455 "Рассылка 
пользователям е-мейлов на основании истории заказов"), 


называют тест-комплектом (1е52 саѕе зийе). 


Что происходит в жизни? 


• получаем новый спек; 

• создаем новый файл, в котором создаем новые тест-кейсы 
для этого нового спека; 

• исполняем новые тест-кейсы с их одновременной модифи- 
кацией (об этом через 45 секунд); 

если имеет смысл, то переносим тест-кейсы в основной 
тест-комплект, где хранятся тест-кейсы, проверяющие ту 
же функциональную часть вашего интернет-проекта. 


Создание нового файла с новым тест-комплектом обусловлено 
тем, что новые тест-кейсы всегда исполняются в первую оче- 
редь и нам просто удобно хранить их отдельно от старых. Как 
говорится, "мухи отдельно, котлеты отдельно" (конечно, до тех 
пор, пока нам это удобно). 


Пример 


На илуу. іеѕіѕһор.г5 можно производить оплату картами МІЅА и Маѕїег- 
Сага. У нас есть тест-комплект, который мы исполняем из релиза в ре- 
лиз (это регрессивное тестирование, о котором мы еще будем много 
говорить), называемый "Покупка с использованием кредитных карт". 


Этот тест-комплект был написан на основании спека #1211 и содержит 
тест-кейсы для проверки функциональностей оплаты с использовани- 
ем МІЅА и МаѕїегСага. 


Для нового релиза написан спек #1422, согласно которому будет на- 
писан код для поддержки новой карты — британской Ѕуиїсћ. 


56 


Тестирование Дот Ком. Часть 1 


Сначала создаем новый тест-комплект "Покупка с использованием 
Зи/йсй", затем исполняем и одновременно модифицируем его. Учиты- 
вая, что 


• после исполнения содержимое тест-комплекта будет стабили- 
зировано и 

• внем проверяется та же функциональная часть веб-сайта ("Оп- 
лата"), 


в данном случае будет логичным сделать его частью тест-комплекта 
"Покупка с использованием кредитных карт". 


Постановка мозгов 


Никто не ожидает, что тест-кейсы будут на 100% 'работать" сразу по- 
сле написания. Дело в том, что они создаются на основании опека 
(или, как это часто бывает, на основании устного пожелания начальни- 
ка), и так как мы физически не видим функциональностей этого опека 
(код еще не написан), то многие вещи нужно в буквальном смысле 
представить себе. Кроме того, как мы уже видели, сами спеки имеют 
баги и спек может быть изменен без ведома тестировщика... (об этом 
позже). 


В общем вариантов множество, и все ведут к тому, что в первый раз 
тест-кейсы должны исполняться их автором, задача которого 


• если необходимо, добавить новые тест-кейсы; 

• если необходимо, внести изменения по сущестеу, например в 
случае, если при создании тест-кейса тестировщик неправильно 
понял спек; 

• если возможно, удалить лишние тест-кейсы, например, если два 
тест-кейса проверяют одну и туже идею, дублируя друг друга; 

• сделать тест-кейсы более удобными для поддержки; 

• отшлифовать их, что означает сделать формулировки кри- 
стально-сверкающе-искристо ясными и точными. 


Вот "шапка", которую можно нацепить поверх тест-кейсов. 


Аиѓілог — автор тест-кейсов. 
рес Ш — номер (или иной уникальный /0) спека. Сам /0 дол- 


жен быть линком к спеку в локальной сети (об этом мы еще 
поговорим). 


Рғіотйу — приоритет тест-комплекта (например, от 1 до 4), обыч- 


но соответствующий приоритету спека. 


Ргодисег — продюсер, написавший спек. 
Реуеюрег — программист, пишущий код в соответствии со спеком. 
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В секции Оуегем? вкратце рассказывается, чему посвящен этот 
тест-комплект. 


Предназначение секции СГОВАГ ЅЕТОР апі АРРІТІОМАІ, ІМЕО 
аналогично секции тест-кейса ЅЕТОР апа АРРІТІОМАІ, ІМЕО, толь- 
ко здесь мы говорим о повторяющихся вещах, которые будем ис- 
пользовать в более чем одном тест-кейсе, и вообще о любой дру- 
гой полезной информации для всего тест-комплекта. 


Вот содержимое файла сгейй саг4_ раутепіѕ.йос, включающего 
тест-комплект "Покупка с использованием кредитных карт": 


Покупка с 
использованием кредитных карт (Т57122)* 


Аи®ог: Ѕрес р: Ргіогіќу Ргодисег: Оеуеорег: 
О. Тарасов 1211 1 П. Хрипунов Н. Назаров 
ОУЕВУТЕУ: 

Данный тест-комплект проверяет оплату картами УІЅА и МаѕіегСага 


СТГОВАГ, ЅЕТОР апа АООГПОМАТГ, 1ХЕО: 

1. _ ЗО: ѕејесі тези Нот сс ігапѕасбоп ућеге 14 = <номер заказа>; 
2. Баланс счета карты можно посмотреть здесь: 
ууугүү.таіп.еѕіѕЅһор.т5/<четыре последних цифры карты>Љаіапсе. ит 


ІЮЕА: Оплата может быть произведена картой УІЅА 
ЅЕТОР апа АррІТІОМАТ 1ХЕО: 


Эккаунт: ќеѕёиѕег1/ра$%%уүОга 

Данные карты: 

Номер: 9999-5148-2222-1277 Окончание действия: 
12/07 СУУ?: 778 


Кеуіѕіоп Ногу 


Сгеае4 оп: 11/17/2003 Ъу О.Тарасов 


Моаіћеа оп: 11/26/2003 Ъу И. Новикова |Шаги были упрощены, чтобы 
сделать тест-кейс более удобным 
для поддержки 


Моаеа оп: 01/17/2003 Бу И. Новикова |Изменение шагов и второй 
ожидаемый результат с целью 
удостоверения в снятии денег со счета 
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Ехесийоп раг 
РВОСЕБОВЕ ЕХРЕСТЕО ВЕЗОГТ 


. Запиши баланс счета карты > "10" 
. Открой ууүуү.та1п.іеѕіѕһор.гѕ 
. Войди в систему. 
. Найди любой товар. 
. Добавь товар в корзину. 
„ Произведи оплату картой из секции 
ЅЕТОР апа АРОІТОМАГ [МЕО 
(!!! запиши полную сумму заказа: 
). 
7. Запиши номер заказа 
8. Запроси базу данных с $011. 


9. Запиши баланс счета карты > Шаг1- Шаг 6 
ТС Ір/Ргіогіќу ССРС0002 


ШЕА: Оплата может быть произведена картой МаѕќегСага 
ЗЕТОР апа АБОТТТОМАГ, ІЧЕО: 

Эккаунт: (еѕѓиѕег 1 /ра$%уОга 

Данные карты: 

Номер: 3333-7112-4444-7844 Окончание действия: 12/08 
СУҮҰ2: 676 


Кеуіѕіоп Ніѕќогу 
Стеаќей оп: 11/17/2003 Бу О.Тарасов 


Моде оп: 11/26/2003 Бу И. Новикова |Шаги были упрощены, чтобы 
сделать тест-кейс более удобным 
для поддержки 


Моде оп: 01/17/2003 Бу И. Новикова |Изменение шагов и второй 
ожидаемый результат с целью 
удостоверения в снятии денег со счета 


Ехесийоп рагі 
РВОСЕБОВЕ ЕХРЕСТЕО ВЕЗОГТ 


. Запиши баланс счета карты > "20" 
Открой угүгү.га1п.іеѕіѕһор.гѕ 
Войди в систему. 
Найди любой товар. 
. Добавь товар в корзину. 
„ Произведи оплату картой из секции 
ЅЕТОР апа АРОІТІОМАГ 1МЕО 
(!!! запиши полную сумму заказа: 
). 
7. Запиши номер заказа 
8. Запроси базу данных с ЗОГ1. 


9. Запиши баланс счета карты > Шаг 1- Шаг б 


(757122) — каждый тест-комплект должен иметь свой уникальный ІР, 
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Прошу обратить внимание на следующее: 


1. Вещи, которые у нас повторяются в разных тест-кейсах, 
вынесены в секцию СГОВАГ ЅЕТОР апа АВОГГОМАЕ ІМЕО 
тест-комплекта: 

1. 501.1: ѕеіесі гезий гот сс іғапѕасііоп уйеге 14— <номер заказа>; 
2. Баланс счета карты можно посмотреть здесь: 
ум. татлеуврорль/<четыре последних цифры карты>/бајаисел іт. 

2. Данные, различающиеся между тест-кейсами ССРС0001 и 
ССРС0002, выделены жирным с подчеркиванием. В предло 
женном тест-комплекте это сделано, чтобы приковать вни 
мание исполнителя к различиям в похожих тест-кейсах. 


В общем случае хорошая практика — пользоваться ВОЗМОЖНО- 
СТЯМИ текстового редактора, чтобы выделить то, на что стоит об- 
ратить внимание. 


Продолжаем. 


Наш менеджер дает нам для проработки и создания тест-кейсов 
новый спек продюсера М. Чучикова: #/422 "Покупка с исполь- 
зованием Зийсй". Мы создаем новый файл: ѕмйсл раутепіѕ.аос. 
И после того как мы его исполнили и причесали наши новые тест- 
кейсы (в данном случае один тест-кейс), получаем: 


Покупка с использованием $үіќеһ (757131) 


Аобог: Ѕрес р: Ргіогіќу Ргодисег: Оеуеорег: 
И. Новикова 1422 1 М.Чучиков Н. Назаров 
ОУЕВУТЕУ: 

Данный тест-комплект проверяет оплату картой З\ИсН 


СГОВАГ, ЅЕТОР апа АррІТІОМАТ ІМЕО: 

1 ЗОШ: ѕеЈесі геѕи от сс ігапѕаспоп ућеге 14 = <номер заказа>; 
2. Баланс счета карты можно посмотреть здесь: 
ууууүү.та1п.іеѕіѕһор.гѕ/<четыре последних цифры карты>/ба1апсе.Һіт 


ТС І/Ргіогіќу $\УРІ.0001 


ІЮЕА: Оплата может быть произведена картой Зууйсев 
ЗЕТОР апа АБОТТТОМАГ, ІЧЕО: 

Эккаунт: ќіеѕёиѕег1/ра$%%үОга 

Данные карты: 

Номер: 3333-1988-4444-5699 Окончание действия: 
12/05 СУУ?: 451 
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Запиши баланс счета карты > "30" 
’ Открой Ұүүуүү.таіп.ќеѕіѕһор.гѕ 
Войди в систему. 
Найди любой товар. 
Добавь товар в корзину. 
Произведи оплату картой из секции 
ТОР апі АПРІТІОМАГ 1МЕО 
(!!! запиши полную сумму заказа: 
). 
7. Запиши номер заказа 
8. Запроси базу данных с $011. 


9. Запиши баланс счета карты $* Шаг 1-Шаг 6 


Теперь нам остается просто объединить оба файла. Таким образом, 
у нас получился а пеу стейй_сагА_раутет5.4ос. Откроем его: 


Покупка с использованием кредитных карт 


Часть 1 тестирование с //54А и МаѕѓіегСата 


Часть 2: тестирование со бийсй 
Часть 1 


<Шапка, ССРС0001 и 2СРС0002 из старого файла стедй аос 
без изменений> 


Часть 2 
<Шапка и 5%РІ0001 из файла .аос без изменений> 


Прошу обратить внимание на следующее: 


мы не меняли 


• ни содержимое файла ѕюйсһ раутепіѕ.Ӣос, которое вста- 
вили в основной тест-комплект сей саға раутепіѕ. дос, 
• ни содержимое старого файла сғейй саға раутепіѕ. ос. 


Можно, например, было сделать для них одну общую "шапку" или 
заменить 5//РГ0001 на ССРС0003 (чтобы иметь единую систему 
нумерации в одном тест-комплекте), но ни этого, ни других объеди- 
нительных мероприятий не было (и не будет) проведено, так как: 


• это два независимых модуля и каждый из них прекрас 
но исполняем по отдельности (пусть даже они и объеди- 
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нены в одном файле (и одном тест-комплекте) из-за того, 
что они покрывают ту же функциональную часть нашего 
проекта); 


• уникальный /Ю тест-кейса дается последнему один раз и 
никогда не меняется. Это как номер налогоплательщика 
— нас ведь нужно учитывать, где бы мы ни были, а то 
располземся, как тараканы, легкомысленно забыв о том, 
что у патрициев тоже есть семьи, которые мы, будучи не 
патрициями, должны содержать, платя налоги. 


Кстати, генерировать уникальный Ш тест-кейса можно 


• автоматически (для этого может быть написана простая про- 
граммка) или же 

• вручную, для чего должна быть заключена конвенция внутри де- 
партамента качества. 


Пример 
Мы договариваемся, что Ш состоит из двух частей: 


• первая часть — это буквенное обозначение (например, четыре 
латинские буквы), а 
• вторая часть — это цифровое обозначение (от 0001 до 9999). 


10 присваивается автором тест-комплекта, и в случае если новые тест- 
кейсы (без 10) добавляются в тест-комплект, то буквенный Ір берется из 
предшествующих тест-кейсов, а цифровое обозначение = максимальное 
цифровое обозначение + 1. Так если мы решим добавить тест-кейс для 
тестирования оплаты картой Ѕиїсһ, то как мы его назовем? Правильно! 
$ЗИ/Р!О002. А картой МІЅА или Ма${егСага? Правильно! ССРС0003. 


Кстати, ССРС — это "СгедЙ Сагаз Раутепіѕ СІоБа!" ("общее по платежам 
с кредитными картами"), а ЗИ/РЕ — "ЗИ/йсй Раутепіѕ Госа!" ("локальное по 
платежам с картой Ѕийсһ"). Почему я выбрал ТАКИЕ буквенные 
обозначения? Потому что мне так захотелось. Никакого правила здесь 
нет, как нравится, так и называйте, но постарайтесь, чтобы не было 
двух тест-кейсов с одним ІР. 


Пример 
Процесс присвоения Ір идет следующим образом: 


1. Пишем тест-кейсы. 10 не присваиваем. 

2. "Обкатываем" их при первом исполнении с удалением тех из них, 
которые недостойны быть частью нашего тест-комплекта, и до- 
бавлением тех, которые пришли на ум по мере исполнения. 

3. Присваиваем оставшимся тест-кейсам по ІР. 


Мы продолжим разговор о тест-комплектах на одном из следую- 
щих чаепитий. 
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Состояния тест-кейса 
У них все, как у людей. Рождаются, изменяются и умирают... 


Рождение: 
состояние — "Новый" (№ и»). 
Это первая редакция тест-кейса: "Сгеше4 оп: 11/17/2003 Бу 
0. Тарасов". 


Изменение: 


состояние — "Измененный" (Моа: еа). Модификации, как 
правило, связаны с изменением спека, затрагивающего этот 
тест-кейс, или с улучшением тест-кейса, например, для 
удобства в поддержке: "Мойіўћей оп: 11/26/2003 Бу И. 
Новикова". 


Смерть тест-кейса наступает 


• вместе со смертью тестируемой вещи (определенной функ- 
циональности, элемента интерфейса пользователя и др.), 
например ууу. ѓеѕіѕйор.тѕ перестал принимать кредитные 
карты либо 

• в других случаях, например когда один тест-кейс дублиру- 
ет другой, т.е. имеем 


состояние — "Более недействителен" (егес). 


Рекомендую не удалять тест-кейсы насовсем, так как 


во-первых, всегда возможна ошибка в суждении и нам нужно 
предусмотреть обратимость удаления, 

во-вторых, тест-кейс, который, по нашему субъективно-несовер- 
шенному мнению, перестал быть актуальным, может еще приго- 
диться, хотя бы как память о годах жизни, проведенных не за 
штурвалом пиратского брига "Черная жемчужина", а за монито- 
ром "Хундаи" с неотдирающимся стикером "Моя компания — 
мой дом". 


В общем: 


1. Создаем специальную директорию в том же месте, где хра 
ним файлы с тест-комплектами, и называем ее 
гейгеа іеѕісаѕеѕ. 

2. Создаем в этой директории файл с тем же именем, что и 
файл тест-комплекта, из которого удаляем тест-кейс. 


Искусство создания тест-кейсов 63 


3. Переносим тест-кейс (си/раяе) из файла, больше не нуж- 
дающегося в этих услугах, в одноименный файл директо- 
рии гейгей іеѕісаѕез. 


В жизни все выглядит проще, так как обычно пускается в расход 
не отдельный тест-кейс, а весь тест-комплект. 


Иногда возникает дилемма — что лучше: 


• изменить тест-кейс или 
• удалить его и придумать НОВЫЙ. 


Зсе ситуации уникальны, но, как показывает жизнь, легче возвести 
здание на пустом месте, чем делать генеральную реставрацию 
старого особняка. Кстати, судя по Москве, этой концепции при- 
держиваюсь не я один. 


Вот такие дела... 


А напоследок я скажу... 
Важный момент перед подведением итогов. 


Все то, о чем мы говорили в ЭТОЙ беседе, является хорошей прак- 
ТИКОЙ при создании тест-кейсов и тест-комплектов, эта практика 
имеет место в реальных и успешных интернет-компаниях Сили- 
КОНОВОЙ Долины, и все, включая формат, можно использовать, 
как оно было рассказано и показано. Я же хочу, чтобы вы всегда 
помнили главное: 


тестирование — это процесс творческий и, следовательно, 
подразумевает поиск. Ищите, пока не найдете то, что эф- 
фективно работает именно в вашей компании и в конкретной 
ситуации. 


Для иллюстрации творческого подхода те же тест-кейсы, но в 
другом виде. 


И Т 
Ір 


Таблица 1 


ССРС0001 УІЅА 9999-5148-2222-1277 [12/07 778 
ССРС0001 3333-7112-4444-7844 | 12/08 
$ҰУРІ.0001 3333-1988-4444-5699 [12/05 
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ТШЕА: Оплата может быть произведена картами из Таблицы 1. 


Для каждого тест-кейса из Таблицы 1: 
1. Запиши баланс счета карты 


ууу лаш.4е55Пор.т5/<четыре последних цифры карты>аапсе. ил 
2. Открой ууүү.таїіп.ѓеѕіѕһор.г. 
3. Войди в систему как ќеѕіџѕег1/ра55%№Ога. 
4. Найди любой товар. 
5. Добавь товар в корзину. 
6. Произведи оплату картой (!! запиши полную сумму заказа: 
7. Запиши номер заказа 
8. Запроси базу данных: 
ѕеЈесї гези от сс ігапѕасіоп ућеге 14 = <номер заказа>; 
Сравни с Ехресќеа геѕиі№і. 


Прошу считать творческий подход проиллюстрированным. 


Краткое подведение итогов 


1. Тест-кейс — это инструмент тестировщика, предназначенный 
для документирования и проверки одного или более ожи- 
даемых результатов. 

2. Шаги (ргоседиге) — это часть тест-кейса, ведущая исполнителя 
тест-кейса к фактическому результату (выводу). Излишняя 
детализация может осложнить поддержку, а излишнее 
абстрагирование привести к непониманию того, как исполнить 
тест-кейс. 

3. Шаги для повторяющихся сценариев можно вынести в отдель- 
ный документ в локальной сети, и в тест-кейсе мы даем лишь 
ссылку на этот документ. 

4. Исполнение тест-кейса завершается либо положительным 
(ра5$), либо отрицательным (ай или баг!!!) результатом. Причем 
именно отрицательный результат является желанным, так как 
мы нашли баг. 

5. Исполнение тест-кейса не является завершенным, если испол- 
нитель не смог "пройти" все шаги. 

6. Тест-кейс должен быть независим от других тест-кейсов из того 
же или любого другого тест-комплекта. 

7. Наиполезнейшими вещами являются следующие атрибуты тест- 
кейса: 


• уникальный /Ю, который уникален в пределах всех сущест- 
вующих в компании тест-кейсов; 
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10. 


11. 


12. 


13. 


14. 


15. 


16. 


17. 


• приоритет, чтобы все знали, кто здесь главный; 

• идея, которая на простом языке объясняет предназначение 
тест-кейса; 

• подготовительная часть, которая... ну, в общем, подго- 
тавливает нас к исполнению тест-кейса; 

• история редактирования, которая помогает указать на 
друзей, испортивших наши идеальные тест-кейсы и наших 
легковерных попугаев. 


Поддерживаемость тест-кейса — это легкость и удобство, с 
которыми он может быть изменен. Поддерживаемость тест- 
кейса — одна из основных формальных вещей при создании или 
модификации тест-кейса. 

Тест-кейс "проверяет" не более одной идеи. При этом два и 
более ожидаемых результата легитимны, если истинность идеи 
вытекает из одновременной истинности этих ожидаемых 
результатов. 

К плохому стилю относятся: 


а) зависимость тест-кейсов друг от друга; 

б) нечеткая формулировка шагов; 

в) нечеткая формулировка идеи тест-кейса и/или ожидаемого 
результата. 


Тест-кейсы объединяются в тест-комплекты (как правило, один 
тест-комплект — это один файл). 

Как правило, тест-комплект включает тест-кейсы, родственные 
друг другу тем, что они проверяют определенный участок на- 
шего интернет-проекта или вещи, описанные в определенном 
спеке. 

Хорошим стилем является создание нового тест-комплекта для 
новых тест-кейсов. 

Тест-кейсы, написанные после проработки спека (до того, как 
представилась возможность "пощупать" написанное по нему ПО), 
являются сырыми, и никто не посмеет бросить в тестировщика 
камень осуждения, если он впоследствии изменит тест-кейсы по 
мере их исполнения. 

Создавая или модифицируя тест-кейсы, мы всегда должны 
помнить о том парне, который будет их исполнять после нас. 
Состояние тест-кейса: "У них все, как у людей. Рождаются, 
изменяются и умирают..." — "Новый", "Измененный", "Более 
недействителен". Хорошая практика — не удалять (тетоуе) 
отжившие свой век тест-кейсы (или целые тест-комплекты), а 
переносить их (тоуе) в отдельную директорию, специально 
созданную для таких пенсионеров. 

Важно понять, что в сегодняшнем разговоре речь шла о форме, 
а не о содержании тест-кейсов. Содержание конкретного тест- 
кейса — это отражение методологии нахождения багов 
применительно к конкретной ситуации, и этой методологии 
будут посвящены отдельные беседы. 
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Вопросы и задания для самопроверки 


Без какой части тест-кейс никак не может обойтись? 

Для чего в тест-кейсе нужны шаги? 

Два вида исхода исполнения тест-кейса. К какому исходу мы, 
как тестировщики, стремимся? 

Что происходит, если состояние ПО не позволяет исполнить все 
шаги тест-кейса? Каковы наши действия? 

Обоснуйте, почему у тест-кейса должна быть лишь одна тести- 
руемая идея? 

Перечислите полезные атрибуты тест-кейса и причину полез- 
ности каждого из них. 

Изменяется ли /0 тест-кейса при изменении самого тест-кейса 
или переносе его в другой документ? 

Придумайте свой способ индексации тест-кейсов, например, 
частью /Р может быть номер спека. 

Что такое ааѓа-агїуеп тест-кейс? В чем заключается удобство 
поддержания такого тест-кейса? 

Как легкость в поддерживаемое“ тест-кейса позволяет сэко- 
номить время? 

Формальные недостатки, не позволяющие тест-кейсам быть 
белыми и пушистыми. 

В чем удобство написания новых тест-кейсов в отдельный тест- 
комплект? 

Ожидается ли, что тестировщик изменит тест-кейс, написанный 
лишь на основании спека, без знакомства с реально напи- 
санным ПО? 

В чем проявляется родственность тест-кейсов, являющихся 
частью одного тест-комплекта? 

Приведите атрибуты шапки тест-комплекта. 

Состояния тест-кейса. 

Почему не рекомендуется удалять тест-кейсы? 

Есть ли стандартная форма тест-кейса, за несоблюдение кото- 
рой лишают премий и не приглашают на празднование Нового 
года? 

Разница между идеей тест-кейса и ожидаемым результатом. 
Напишите тест-кейс с тестируемой идеей "Я могу убедить свою 
жену в чем угодно" и ожидаемым результатом "Дорогой, поез- 
жайте с Алексеем на рыбалку. Вы так редко с ним видитесь". 
Напишите тест-кейс с одной идеей и двумя ожидаемыми ре- 
зультатами. Используйте пример из жизни. 


ЦИКЛ РАЗРАБОТКИ ПО 


• ИДЕЯ 

• РАЗРАБОТКА ДИЗАЙНА ПРОДУКТА И СОЗДАНИЕ 
ОПЕКА 

• КОДИРОВАНИЕ 

® ИСПОЛНЕНИЕ ТЕСТИРОВАНИЯ И РЕМОНТ БАГОВ 

• РЕЛИЗ 

® БОЛЬШАЯ КАРТИНА ЦИКЛА РАЗРАБОТКИ ПО 


Ц (процесс) разработки ПО (ѕо/ћђаге деуеіортепі Ше 
сусІе) — это путь от идеи до поддержки готового продукта. 
Чем более отлажены каждая из стадий цикла и координация меж- 
ду ними, тем эффективнее работает интернет-компания, тем вы- 
ше качество и тем счастливее пользователи. 


Сегодня мы поговорим о модели цикла разработки ПО, называе- 
мой "ИшеаЙ" ("Водопад"), которая используется в подавляю- 
щем большинстве интернет-стартапов. 


Наша цель — понять логику взаимосвязи между стадиями 
Цикла и основные моменты каждой из стадий. 


Большая картина цикла будет представлена в конце разговора, 
когда будет понятно, что уже ничего не понятно. 


Постараюсь свести к минимуму вещи типа: "в одних компаниях 
Э 

‘по называется так, а в других — этак", нельзя объять необъ- 
ятное, но если будет схвачен принцип, то, несмотря на разницу 
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— Помните, дети, что мы про- 
изошли не от Бага-Прародителя, 
а от халатного отношения к каче- 
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в названиях и нюансах, вы мгновенно свяжете то, о чем я вам 
рассказал, с тем, что есть (будет) в компании, где вы работае- 
те (несомненно, будете работать). 


Итак, поприветствуем участниц и участников нашего шоу. Ими 
сегодня будут: 


1. Идея. 


2. Разработка дизайна продукта и создание документации. 
3. Кодирование (в смысле создание кода). 

4. Исполнение тестирования и ремонт багов. 

5. Релиз. 


Дизайн 
и документация 


Тестирование 
и ремонт 


Ш: 


Для начала расскажу вам, как образовывались стартапы в США в 
конце 90-х гг. прошлого века. И не подумайте, что я утрирую. 


Калифорнийская история 


Сидят два бывших одноклассника в спорт-баре даунтауна Сан-Фран- 
циско и думают, как заработать денег: кругом интернет-бум, некото- 
рые друзья стали миллионерами и ездят на сверкающих "Феррари" 
между офисами-аквариумами интернет-компаний и своими домами 
на холмах Лос-Алтоса. 
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Один из них неожиданно поднимает над барной стойкой голову, переводит озаренный 
взгляд на другого, вытягивает вверх указательный палец и говорит: "О!" 


Это "О!" означает рождение идеи, например, о создании веб-сайта по продаже 
туалетной бумаги. 


На следующий день раздается звонок в офисе венчурного капиталиста и назначается 
встреча для обсуждения "проекта века". 


Кстати, 
венчурные капиталисты — это такие непростые товарищи, бизнесом которых 
является спонсирование новых компаний. 


Встреча проходит в теплой и дружественной обстановке, и под проект "Туалетная 
бумага Дот Ком" дается 50 млн долл. 


Сказавший "О!" становится СЕО (СШеЁ Ехесиїме Ойісег), а егодруган — 
соответственно СОО (СШеЁ Орегайпд Ойісег). 


Снимается помещение, покупаются ораклы и линуксы, начинается набор народа на 
рядовые и руководящие должности, день и ночь кипит работа, пепперони-пицца 
становится ежедневной едой даже вегетарианцев, жены программистов изменяют со 
страховыми агентами, в общем все "счастливы, влюблены, раздавлены". 


Процесс пошел!!! 


Слушая эту историю, которая вполне могла быть правдивой, можно 
заметить, что все началось с "О!", т.е. с ИДЕИ. 


Вопрос: Кто генерирует идеи в действующей интернет-компании? Ответ: 
Как правило, это отдел маркетинга. Нередко идеи инициируются службой 
поддержки пользователей или новым контрактом, например, с компанией 
по процессингу кредитных карт (стей сага ргосе5зог). 


В общем вариантов множество. 


При разговоре о большой картине сводному персонажу, генерирующему 
идеи, будет присвоено имя Маркетолог. 


Как правило, идеи компонуются в МАР ("эм-ар-ди" — Мажейие 
Кедиіғетепіѕ Поситет — документ о требованиях маркетинга, суть 
которого: "хотелось бы это иметь"). 


Затем 


• менеджмент проворачивает МЕОШКИ через жернова анализа, 
утверждения и приоритезации, а 

• выжившие идеи передаются продюсерам, которые их полоскают, 
высушивают и гладят, чтобы получилась спецификация. 
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Разработка дизайна продукта и 
создание опека 


На основании идеи, утвержденной менеджментом, разрабатыва- 
ется и документируется ее воплощение, которое называется 
дизайном продукта (ргойисі 4еяет) или, простыми словами, то, 
как та или иная часть нашего веб-сайта должна выглядеть и/или 
работать. 


Концептуальная разница между идеей (продукта) и дизайном 
(продукта) заключается в том, что 


• идея — это описание ЦЕЛИ, а 
• дизайн — это описание ПУТИ к достижению этой цели. 


Профессионально весь этот джаз осуществляется менеджерами 
продукта (РМѕ — РгойисЕ Мапазег$), которые также могут назы- 
ваться продюсерами (Ргойисегѕ) или дизайнерами продукта (Ргодис! 
Реѕіепер). 


Результатом продюсерских усилий являются спеки, называемые 
также РАР (Ргойисі Кедиігетепіѕ Поситепі — документ о требова- 
ниях для продукта) или просто гефиігетепіѕ (требования). 


Самые эффективные продюсеры в интернет-компаниях — это 
профессионалы, имеющие бэкграунд в предмете, на котором они 
специализируются, и ненавязчивую техническую подготовку. 


Первое необходимо, чтобы детально разбираться в том, что 
найдет отражение в спеках (например, это могут быть правила 
торгов НАУФОР). 


Второе полезно, чтобы говорить на языке программистов и 
тестировщиков. 


Спеки должны иметь уникальное название и уникальный Ш 
и внутри разбиваются на логические составляющие (части, пункты), 
имеющие индексацию для удобства ссылок. 


Каждый спек имеет также обозначение своей важности (при- 
оритета). Обычно это цифра по 4-балльной шкале. Так, спек 
приоритета 1 (Ш) — это самый приоритетный спек. 


Практическая ценность придания спекам приоритетности 
состоит в следующем: 
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если речь идет об исключении каких-либо функционально- 
стей из релиза, так как не хватает ресурсов (например, 
времени у программиста), то жертвуют функционально 
стью из спека с меньшим приоритетом. Так, при наличии 


одного спека с Ши 
другого спека с П2, 


равноценных по трудоемкости для программиста и тести- 
ровщика, отбрасывается П2; 


программист и тестировщик всегда должны начинать (про- 
граммирование, подготовку к тестированию и исполнение 
тестирования) со спека с большим приоритетом; 


так как мы знаем, что невозможно протестировать все, 
приоритет спека для тестировщика — знак, указы- 
вающий, чему нужно дать больше любви и заботы. 


Как правило, приоритет присваивается спекам менеджером про- 
дюсеров. 


Идем дальше. 


Хороший спек, каки хороший закон, отличают следующие вещи: 


мео лро 


Акцент на деталях и их четкое определение. 

Забота о недопущении неверного толкования. 
Непротиворечивость внутри спека и с другими спеками. 
Логическая взаимосвязь компонентов. 

Полнота охвата предмета. 

Соответствие нормативным актам. 

Соответствие деловой практике. 


Ошибки в спеке появляются в случае отклонения содержания 
спека от пунктов 1 —7. 


1. АКЦЕНТ НА ДЕТАЛЯХ И ИХ ЧЕТКОЕ ОПРЕДЕЛЕНИЕ 


Пример ошибки 
"1.5. При регистрации система должна проверить е-мейл на наличие: 


перед именем глобального домена (например, "ш" или "сот")". В 


этом спеке пропущено множество вещей. Например: 


а. Не указано, что е-мейла с двумя "@" быть не может. 

6. Не указаны другие неприемлемые знаки (еда! сһагасіегѕ) е-мейл- 
адреса. 

в. Не приведен список существующих глобальных доменов. 
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Пример последствий ошибки 


Стандартная практика регистрации нового пользователя состоит из 
трех этапов: 


а. Пользователь заполняет регистрационную форму и нажимает 
кнопку "Зарегистрироваться". 

6. От веб-сайта приходит е-мейл с липком для подтверждения ре 
гистрации. 

в. Пользователь кликает линк, и регистрация автоматически под 
тверждается. 


Если пользователь случайно введет неправильный е-мейл (например, 
с двумя "@") и сообщение об ошибке сгенерировано не будет, то реги- 
страция не будет завершена, так как е-мейл с липком для подтвержде- 
ния регистрации не придет. Пользователь будет бесполезно ждать 
этого е-мейла, а не дождавшись, скорее всего введет в адресной 
строке веб-браузера ЦИРКЕ конкурента. 


Кстати, ОРІ ("ю-ар-эл" — Ипотт Кезоигсе Госаїог) — это просто ад- 
рес файла в сети, например "ВЁр:/Имиии4ез1пор.г5". ИКЁ можно вво- 
дить в адресную строку веб-браузера без "И#р://" (ее добавляет сам 
браузер при запросе к веб-серверу). Имя файла может даваться на- 
прямую: иммми.тат4е${5Пор.г5/1277/Ба!апсе.Шт, либо веб-сервер сам 
найдет для нас нужный файл в соответствии со своими настройками, 
например, в случае с нашим проектом набор в адресной строке 
браузера "им. таіп.іеѕіѕһор.гѕ" или "мм. таіп.іеѕіѕһор.гѕ/іпаех.Һіт" 
даст нам тот же самый файл іпаех.һіт. 


2. ЗАБОТА О НЕДОПУЩЕНИИ НЕВЕРНОГО ТОЛКОВАНИЯ 


Пример ошибки 


Игорь Саруханов. Песня "Скрип колеса". 

Произнесите вслух название этой песни. Я, например, многие годы 
думал, что песня называется "Скрипка лиса", а моя жена была уверена, 
что "Скрипка. Леса...". 


Пример последствий ошибки 


Если для вашей профессиональной деятельности не имеет никакого 
значения, как называлась эта песня, то адекватность понимания спека — 
это вещь наиважнейшая. Опасность заключается в том, что 


программист и/или 
тестировщик, 


выбрав неправильный смысловой вариант, может быть уверен, что все 
понял правильно, и в итоге напортачит 


с кодом и/или с 
тест-кейсами. 


У нас будет отдельное рассмотрение того, как превентировать 
возможность неверного толкования спека. 
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3. НЕПРОТИВОРЕЧИВОСТЬ ВНУТРИ СПЕКА И 
С ДРУГИМИ СПЕКАМИ 


Пример ошибки 


"7.3. В целях безопасности доставка может быть осуществлена на 
адрес пользователя, по которому зарегистрирована кредитная 
карта" 


и на следующей странице или в другом спеке: 


"8.1.1. Для доставки пользователь может ввести любой адрес в преде- 
лах континентальной части США". 


Пример последствий ошибки 


Один программист может запретить доставку на любой адрес, кроме 
адреса регистрации кредитной карты, а другой программист незави- 
симо от первого напишет код, позволяющий пользователю ввести лю- 
бой адрес, который тот пожелает. 


Вследствие этого вполне возможна ситуация, когда пользователь, за- 
вершив заказ, будет ждать посылку, которая никогда к нему не придет, 
так как система 


• позволит сделать заказ (код второго программиста), НО 
• не даст команду кладовщику, чтобы тот послал заказ по почте 
(код первого программиста). 


4. ЛОГИЧЕСКАЯ ВЗАИМОСВЯЗЬ КОМПОНЕНТОВ 


Пример ошибки 


"1.1. Мои мама и папа, я живу хорошо, просто замечательно. У меня 
все есть. Есть свой дом. Он теплый. В нем одна комната и кухня. Я без 
вас очень скучаю, особенно по вечерам. 


1.2. А здоровье мое не очень. То лапы ломит, то хвост отваливается. 


1.3. А на днях я линять начал: старая шерсть с меня сыплется, хоть в 
дом не заходи, зато новая растет — чистая, шелковистая. Так что лох- 
матость у меня повысилась. 


До свидания. Ваш сын, дядя Шарик". 


Спасибо Эдуарду Успенскому за иллюстрацию "логической" взаи- 
мосвязанности компонентов. 


Пример последствий ошибки 


Вспомните реакцию мамы, а затем папы дяди Федора после прочтения 
письмеца. Примерно то же самое может быть с пользователем, когда 
он столкнется с функциональностью, написанной и протестированной 
согласно подобному спеку. 
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5. ПОЛНОТА ОХВАТА ПРЕДМЕТА 


Пример ошибки 


В условиях массового интернет-мошенничества с кредитными кар- 
тами дополнительной степенью защиты является С\\2 (Сага Мепйса- 
{оп Маше 2) — трех- (для всех карт, кроме Атех) или четырехзначный 
(только для Атех) номер, идущий за номером карты на обратной ее 
стороне (на полоске с подписью). Продюсер по незнанию или по ха- 
латности может не предусмотреть в опеке, что пользователь должен 
ввести С\№\2 при регистрации карты, что в итоге приведет к большему 
числу мошеннических транзакций. 


Пример последствий ошибки 


Многие интернет-компании, включая платежные системы, закончили 
существование из-за огромного количества транзакций с крадеными 
картами. Даже если дело не дойдет до закрытия компании, службе 
поддержки клиентов, финансовому и правовому департаментам пред- 
стоит испытать много чудных мгновений, которых могло не быть, не за- 
будь продюсер о СМУ2. 


6. СООТВЕТСТВИЕ НОРМАТИВНЫМ АКТАМ 


Пример ошибки 


Здесь, как правило, речь идет о продаже специальных предметов (на- 
пример, рецептурных лекарств). В этом случае спек (например, в он- 
лайн-аптеке) должен предусматривать, что такие предметы не могут 
продаваться. 


Еще одним примером являются вещи, связанные с авторским 
правом, например распространение аудиофайлов. 


Пример последствий ошибки 


Возможно судебное преследование. Вспомните историю компании 
Марѕїег. 


7. СООТВЕТСТВИЕ ДЕЛОВОЙ ПРАКТИКЕ 


Пример ошибки 


Если денежный перевод обычно занимает 3 — 6 бизнес-дней включи- 
тельно, то пользователю не должно сообщаться меньшее или "точное" 
количество дней. Нужно так и указать на соответствующей странице 
сайта: "Денежный перевод обычно занимает 3 — 6 дней включительно". 


Пример последствий ошибки 


Пользователь будет уверен, что в конкретный день на его счете будет 
определенная сумма. Представьте себе ситуацию, что пользователь, 
рассчитывая на эти деньги, поехал в Лондон на аукцион русской живо- 
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писи, выиграл там картину Айвазовского, за 200 тыс. фунтов, расплачи- 
вается своей дебетовой картой, а ему говорят, что на карте нет денег. 
Останется ли он клиентом нашей компании? 


Идем дальше. 


Некоторые продюсеры убеждены, что спеки должны давать про- 
граммистам указания по сугубо техническим аспектам кодирова- 
ния, как, например, об установлении связей между таблицами В 
базе данных или о названиях функций в коде. Если они не пони- 
мают всех проблем, вытекающих из этого порочного подхода, и 
слушать никого не хотят, предложите им самим написать весь 
код. Скорее всего, они откажутся... 


Пример 

Где-нибудь в городе М в стенах прихватизированного авиационного 
завода открывается фирма по отливке золотых унитазов для новых 
русских. Жена одного такого приезжает на завод и говорит: "Хочу, что- 
бы мой унитаз: 


с 00:00 до 5:59:59 проигрывал в стерео сочинения Сибелиуса в испол- 
нении оркестра английской Королевской оперы; 

с 6:00 до 11:59:59 голосом Марчелло Мастроянни читал пелевинскую 
"Жизнь насекомых"; 

с 12:00 до 17:59:59 философски молчал; с 18:00до 

23:59:59 транслировал "Народное радио", а для 

формы подойдет модель 5 из вашего каталога". 


Очень даже приличная спецификация. И на этом неплохо было бы ос- 
тановиться, но если эта дама с многокаратными каменьями начнет да- 
вать ценные указания о температуре нагревания презренного металла 
перед литьем, изоляции контактов или моменте вступления кларнета в 
Седьмой симфонии, то будет совсем худо. Давайте уж так: каждый 
должен заниматься своим делом. 


Итак, после проведения водораздела между работой продюсера и 
работой программиста продолжим о спеках. 


Спеки имеют следующую очередность статусов: 


1. Во время написания они имеют статус Черновик (Рай). 
Продюсер пишет спек. 


2. После написания и до утверждения — Ожидание утвер- 
ждения (Арргоуа! Реп тв). 
Спек написан, и назначается совещание (теейи®) с про- 
граммистами и тестировщиками по его обсуждению или 
же просто им посылается е-мейл с приложением. 
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3. После утверждения — Утверждено (Арргоуей или Еіпа1). 
Если на митинге все закричали "Ура!" или получены по- 
ложительные отзывы от всех реципиентов, утвержденный 
спек немедленно выкладывается на один из серверов в ло- 
кальной сети, чтобы быть доступным любому лицу внутри 
компании, которому положено его видеть. Если же спек не 
принят, то все начинается с пункта 1. 


Постановка мозгов 


Факт утверждения спека не означает, что тестировщик и программист 
объявили спек идеальным. Факт утверждения спека означает, что в 
результате первоначального ознакомления со спеком последний 
был признан годным для дальнейшей работы. Политический момент: 
спек — это ответственность продюсера, и продюсер остается ответ- 
ственным за качество спека даже в том случае, если программист 
и тестировщик утвердили спек, в котором позднее были найдены 
проблемы. 


Идем дальше. 


Спасский после игры с Фишером неделями ходит и думает: "А вот 
здесь нужно было бы его конем пришкварить", но, к сожалению, 
исправить ему уже ничего нельзя, "можно только забыть". 


Продюсер же может проснуться утром с идеей улучшения спека 
или вспомнить какую-нибудь важную вещь, упущенную при соз- 
дании спека, и, придя на работу, подредактировать спек и заме- 
нить файл со старой редакцией файлом с новой редакцией на 
упомянутом внутреннем сервере... И так пять раз. 


Далее. 


Обычно спек распечатывается непосредственно перед началом 
работы по нему. Учитывая, что время начала работы по спеку у 
каждого индивидуально (я говорю о минутах), если спек будет 
по-тихому изменяться между распечатываниями, наступит ситуа- 
ция, когда 


программисты и тестировщики хотя и работают над одним 
проектом, но руководствуются разными редакциями спека. 


Причем даже если у программистов и тестировщиков будут рас- 
печатки одной и той же версии спека, то в случае тихого измене- 
НИЯ ИХ работа в той или иной части все равно не будет иметь 
смысла, Так как они руководствовались устаревшей редакцией. 
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Пример 
11 ноября. Спек утвержден Ножовым, Ложкиным и Тарелкиным. Про- 
дюсер Буханкин. 
12 ноября. Спек распечатывает тестировщик Ножов. Работа по спеку 
началась. 
14 ноября. У Буханкина новая идея. Спек по-тихому изменен. 
15 ноября. Спек распечатывает для себя программист Ложкин. Работа 
по спеку началась. 
16 ноября. У Буханкина новая идея. Спек по-тихому изменен. 
17 ноября. Спек распечатывает для себя программистТарелкин. Работа 
по спеку началась. 
18 ноября. У Буханкина новая идея. Спек по-тихому изменен. 
19 ноября. Спек распечатывает для себя программист Салфетка, рабо- 
тающий над кодом по интеграции функциональности кода из этого 
и своего спека. Работа по спеку началась. 
25 декабря. Все выясняется. 30 
декабря. 
17:00 — начало празднования Нового года в офисе компании. 
17:30 — начало избиения Буханкина руками Ножова, Ложкина и Та- 
релкина. 
18:00 — начало избиения Буханкина ногами Ножова, Ложкина и Та- 
релкина. 
18:30 — в офис влетает Салфетка, вернувшийся после разговора с 
менеджером, разбрасывает в стороны подуставших Ножова, 
Ложкина и Тарелкина и добивает Буханкина контрольным 
ударом клавой по голове. 


Надо отметить, что во многих случаях спек меняется не по воле 
продюсера, а по приказу сверху. 


Ситуация 


25 марта. 


Менеджер присылает продюсеру е-мейл, что необходимо срочно 
изменить спек #8337. 


За день до этого, т.е. 24 марта. 
Представьте себя на месте продюсера: 
продюсер уже вовсю работает над новым спеком и надеется, что 
релиз функциональностей согласно спеку #8337 пройдет без сучка 
без задоринки. 
Представьте себя на месте программиста: код для спека 
#8337 написан, влегкую протестирован самим программистом, 
частично позабыт и уже кажется частью безвозвратно потерянной 
юности. 
Представьте себя на месте тестировщика: 
документация для тестирования спека #8337 написана. Новые проекты 
быютв паруса, инастоящее наконец-то стало залечивать раны прошлого. 
На следующий день, т.е. 26 марта. 
Спек #8337, а также код и тест-кейсы к нему должны быть изменены, 
т.е. минимум трое работников должны 
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• бросить текущие проекты, 
• вспомнить спек #8337, понять изменения к нему и 
• потратить время на воплощение изменений. 


Эта ситуация является идеальной питательной средой для воз- 
никновения багов, так как это будет работа (включая продюсера) 
на скорую руку, как правило, без возможности погрузиться в этот 
прошлый проект и понять риск внесения изменений. Мало того, 
новые проекты также могут 


а) пострадать или 
б) даже быть отложенными 
из-за того, что 


а) на них будет потрачено меньше времени или 
б) времени может физически не хватить. 


Что же нам делать, чтобы избежать кордебалета с изменяю- 
щимися спеками? 


Если менеджер говорит, что нужно изменить спек, или продюсер 
"вспомнил" о реально важной вещи для спека и эти "НУЖНО" 
или "ВСПОМНИЛ" приходятся на самое наинеподходящее время, 
то никуда не денешься, но все же две очень нехорошие ситуации, 
связанные с изменением спека, можно превентировать. 


Две нехорошие ситуации: 


1. Спек может быть изменен по-тихому. 
2. Изменения к спеку не утверждены программистом и тес- 
тировщиком. 


Вопрос: Как конкретно мы превентируем две нехорошие ситуации? 
Ответ: Мы заморозим спек. 


В любой интернет-компании существует программа контроля за 
версиями. Во многих случаях это старая добрая СУ ("си-ви-эс" — 
Сопсиггет Үегѕіоп 5уѕіет — система по согласованным версиям). 


СУ5 — вещь многофункциональная, и мы о ней еще поговорим, 
но сейчас она нам будет полезна для следующего: 


1. С помощью СУ5 продюсер может сохранять версии спека и 
всегда вернуться к старым редакциям. 

2. С помощью СУ$5 можно "закрыть" директорию так, чтобы 
документы из этой директории могли читаться, но не мог- 
ли редактироваться. 
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Процессуально все можно сделать так: 


1. К определенной дате все спеки должны быть утверждены. 
Неутвержденный спек не кодируется, и точка. 

2: Директория со всеми утвержденными спеками закрывается, 
и никто ничего не может изменить в этой директории... 


„если только не будет следовать процедуре изменения спека. 


Кстати, 


техническую сторону, связанную с заморозкой спеков (ѕрес їгееге), обес- 
печивают инженеры по релизу. 


Процедура включает: 


1. Утверждение всех изменений составом лиц, утвердившим 
предыдущую редакцию. 

2. Посылку е-мейла с перечислением изменений и именами 
утвердивших всем департаментам, непосредственно свя- 
занным с разработкой ПО (продюсеры, программисты, 
тестировщики и инженеры по релизу). Одно из хороших 
качеств такого е-мейла — это то, что люди, не участво- 
вавшие в пункте 1 и имеющие старую версию спека, тоже 
узнают об изменениях. 

3. Открытие СУ5-директории для закладки файла и ее закрытие. 


Конечно, без изменений в спеках не обойтись, но путем 


1) замораживания спеков; 

2) введения процедуры изменения спека; 

3) тщательного рассмотрения необходимости каждого из- 
менения спека с участием менеджмента 


можно превентировать ряд серьезных проблем с качеством. 


Идем дальше. 


Одна из частых причин, по которым в ПО появляются баги кода, — 
это неверное толкование спека (ттіѕіпѓіегргеіайоп) — ситуация, 
когда программисты и/или тестировщики, работающие со спе- 
ком, понимают по-своему то, что пытался донести до них продю- 
сер, и при этом 


• на 100% уверены, что на 100% понимают то, что имел в 
виду продюсер, и, 

• имея уверенность, не уточняют, так как не будешь же бе- 
гать за уточнениями того, что тебе и так ясно. 
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Причина неверного толкования спека может быть связана 


• с одной стороны, с возможностью множественного тол- 
кования некой части спека и, 

• с другой — с тем фактом, что многие вещи в этой жизни, 
для того чтобы быть адекватно понятыми разными людь- 
ми, нуждаются в многоплановой презентации. 


Кстати, именно поэтому на чертеже физического объекта (например, 
двигателя мотоцикла) последний обычно изображается с трех сторон: 
вид спереди, вид сверху и вид слева. 


Тезис 


Тестировщики должны настаивать, чтобы спеки по максимуму 
иллюстрировались: 


• макетами (тоск-ир), 
• блок-схемами (оу сћаті), 
• примерами (ехатр/е). 


Аргументация 


С примерами все понятно: написал что-то — придумай пример 
для иллюстрации, заодно и сам лучше поймешь, о чем пишешь. 


Народная мудрость гласит: "Лучше один раз увидеть, чем сто раз 
услышать". Отличной идеей является разработка продюсером 
макетов интерфейса пользователя (Оѕеғ Гпіегјасе или просто (1 — 
"ю-ай"). Делается это так: 


во время (или после) написания спека продюсер берет генератор 
веб-страниц типа Мсгозой ЕготРазе и путем нехитрых манипу- 
ляций создает веб-страницу с кнопками, полями, картинками и 
прочими милыми деталями интерфейса. 


Затем эта страничка "подшивается" к спеку и помогает всем за- 
интересованным лицам увидеть, ЧТО, по замыслу продюсера, 
должен будет увидеть пользователь. 


Кстати, если спецификация предусматривает, что пользователь будет 
проходить через несколько веб-страниц для совершения какого-либо 
действия (например, покупки книги), то макеты этих веб-страниц могут 
не только являться частью спека, но и служить в качестве обоев, если 
их развесить на стенах офиса в том порядке, в котором их будет видеть 
пользователь. 
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Пример 


Вольное изложение опека #1023 "Регистрация нового пользователя": 
Регистрация пользователя состоит из трех страниц, идущих в следую- 
щем порядке: 


• первая страница (1) — поле для индекса места жительства 
пользователя и кнопка "Продолжить регистрацию"; 

вторая страница (2) — поля для имени, фамилии, е-мейла и па- 
роля/подтверждения пароля пользователя, кнопка "Зарегистри- 
роваться"; 

• третья страница (3) — текст с подтверждением регистрации. 


Все поля обязательны для заполнения, и если на странице (1) или (2) 
вводится недействительное либо пустое значение любого поля, то 
пользователю показывается та же страница, но с сообщением об 
ошибке (етог теѕѕаде). (В данном случае мы не будем говорить о том, 
какой ввод действителен (пегитимен) для каждого из полей, так как это 
сейчас неважно.) 


Продюсер разрабатывает три страницы, распечатывает их в двух ком- 
плектах, один из которых подшивает к спеку, а другой развешивает на 
стене в порядке появления перед пользователем: страница (1), стра- 
ница (2), страница (3). 


Оговорка 1: Макеты могут быть разной степени детализации, и 
вполне допустимо, когда элементы интерфейса, не имеющие от- 
ношения к иллюстрируемому спеку, не включаются в макет, на- 
пример, в случае с макетами для регистрации нас не интересуют 
картинки на веб-странице. 


Оговорка 2: Понятно, что макеты интерфейса пользователя не 
создаются, если спек полностью посвящен бэк-энду веб-сайта 
(например, спек "Автоматизация отчетов по продажам"), так как 
детали интерфейса пользователя, т.е. фронт-энд, в таком спеке 
просто не упоминаются. 


Проблема макетов (даже развешанных правильно) заключается в 
том, что они позволяют увидеть в первую очередь интерфейс 
пользователя, а не логику работы кода позади интерфейса, на- 
зываемую алгоритмом программы. 


Интерфейс — это то, ЧТО видит пользователь, а алгоритм — 
это то, ПОЧЕМУ пользователь видит то, что он видит. 


Для графической презентации алгоритмов используются блок- 
схемы, так горячо любимые всеми выпускниками математиче- 
ского класса выпуска 1990 г. люберецкой школы № 12. 
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Представим предыдущую ситуацию с регистрацией, но в форме блок- 
схемы (такая блок-схема называется ргосеѕѕ Їои свай, так как устроена 


по схеме ввод->процесс->вывод). 


Страница (1) 
“Регистрация” 


Заполнение и ввод 
страницы (1) 


Данные 
легитимны? 


Поле "Индекс" 
заполнено? 


Заполнение и ввод 
страницы (2) 


Поля 
"Имя", "Фамилия" 
"Е-майл", “Пароль", 
“Подтверждение пароля” 
заполнены? 


Данные 
легитимны? 


Страница (3) 
“Подтверждение 
регистрации" 


Кстати, блок-схемы могут создаваться как продюсером, так и 
тестировщиком, но независимо от составителя, как правило, 
прекрасной идеей является включение блок-схемы в секцию тест- 


комплекта СГОВАГ 5ЕТОР апа АРПІТІОМАГ ІМЕО. 


Блок-схемы, макеты и примеры (вместе именуемые БМП) помо- 
гают превентировать появление багов или найти баги на 


уровне спека следующими путями: 
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• БМП — это описание предмета с разных сторон, что ведет 
к его адекватному толкованию разными людьми; 

• создание БМП — это процесс переосмысления написан- 
ного, что ведет к нахождению багов в написанном, т.е. в 
спеке; 

• макеты и блок-схемы наглядны и во многих случаях по- 
зволяют в буквальном смысле увидеть баги в отличие от 
ситуации, когда есть только текст. 


Еще раз: тестировщики должны настаивать, чтобы спеки по 
максимуму иллюстрировались макетами (тоск-ир), блок-схе- 
мами (оу спа") и примерами (ехатр/е). 


Теперь, после того как вы услышали про макеты и пошли дальше, 
не увидев их (что было сделано намеренно — с целью дать вам 
прочувствовать контраст между работой без макетов и с ними), 
позвольте представить вам макеты "Регистрации": 


Макет страницы (1) 


Индекс места жительства*: | 
Продолжить регистрацию | 


е поле обязательно для заполнения 


Макет страницы (2) 


Имя*: | | 
Фамилия : | 
Е-мейл“: | | 


Пароль*: | | 


Подтверждение 
пароля“: | 
Зарегистрироваться | 


* поле обязательно для заполнения 
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Макет страницы (3) 


Регистрация завершена, Нажмите сюда для 
логина 


Бонус: Макет страницы (2) в случае ошибки пользователя при 
заполнении поля "Е-мейл" 


Ошибка 


| Проверьте правильность заполнения поля: 
Е-мейл 


2. Заново введите пароль 


Имя*: | Иван 
Фамипия | Петров 
Е-мейл": | реноу@@зотерасе.сот | 
Пароль“: | | 
Подтверждение 
Зарегистрироваться | 


* поле обязательно для заполнения 


Кстати, макет страницы (2) и бонус-макет страницы (2) противоречат 
спеку: по спеку поле "Фамилия" является обязательным для заполнения, но 
на макетах оно не выделено звездочкой. Противоречие внутри спека — 
это баг, так как любая инструкция теряет смысл, если ее указания не 
стыкуются друг с другом. 


Постановка мозгов 


При обнаружении противоречий внутри спека (а БМП — это части спека!) 
нужно сделать рапорт о баге против продюсера, чтобы тот настроил в 
унисон несогласующиеся части. В нашем случае продюсер должен из- 
менить либо текстовую часть спека ("все поля являются обязательными, 
кроме поля "Фамилия"), либо соответствующие макеты (добавить 
звездочку к полю "Фамилия"). 


Идем дальше. 
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В заключение краткого экскурса о спеках дам еще одну полезную 
идею. 


Каждая более или менее уважающая себя компания имеет свой 
сайт в локальной сети (їпѓіғапе!), который недоступен внешним 
пользователям. На этом сайте можно прочитать тезисы о корпо- 
ративной морали, узнать имя любимого лемура президента ком- 
пании, посмотреть фотографии тех, кто по-тихому правит утвер- 
жденные спеки, и найти много другой полезной информации. Так 
вот, все когда-либо утвержденные спеки должны быть выло- 
жены на этот сайт. При этом они группируются по номеру релиза 
и доступны для просмотра, поиска по директориям (название 
директории — номер релиза), //), ключевым словам в названии и 
имени продюсера. Если спек ссылается на внешний документ 
(например, на правила расчетов Центрального банка), то спек 
должен содержать гиперлинк на адрес такого документа в локаль- 
ной сети. 


Постановка мозгов 


Не стесняйтесь рапортовать баги, которые вы будете находить в 
спеках. Если продюсеры не понимают, то объясните им без пере- 
водчика, что баги, посеянные в спеке, могут, как зараза, перенестись 
в код и тест-кейсы и баг, найденный раньше, стоит компании дешевле 
(06 этом чуть позже), а посему учет таких багов является не правом, 
а обязанностью тестировщиков. 


Следующий этап цикла разработки ПО — это кодирование, осу- 
ществляемое программистами (в то время как тестировщики 
планируют проверку пишущегося кода). 


Кодирование 


Работа программиста заключается в том, чтобы перевести вещи, 
отраженные в спецификации (или словах босса), на язык про- 
граммирования. 


Перевод осуществляется 


• напрямую, т.е. программист берет спек и напрямую кодирует 
его предписания (плохая, недальновидная и опасная идея), 

• или после создания внутреннего дизайна кода, т.е. сугубо 
технической документации, планирующей, как требова- 
ния спека будут воплощены в коде (хорошая, дальновидная 
и благодарная идея). 
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К документам о внутреннем дизайне кода относятся, например, 


• документ о дизайне /архитектуре системы (5уяет /Агсййес- 
шге Реѕіеп Поситепі); 
• документ о дизайне кода (Сойе Реѕісп Поситеті). 


развитие культуры создания и поддержания документации о 
внутреннем дизайне кода — это один из признаков, что стар- 
тап из шарашкиной конторы (пусть даже и с миллионным 
финансированием) превращается в серьезную софтверную 
компанию. 


Идем дальше. 


В идеальном случае каждый программист имеет личную версию 
сайта (или ріауогоипа— игровую площадку), в которую входят: 


• веб-сервер (уер 5егуег); 
• сервер с приложением (аррйсайоп ѕегуег); 
• база данных (аіараѕе). 


Коротко остановимся на каждом из этих компонентов. 


Пример 


1. Пользователь набирает в браузере: иим.іеѕіѕһор.гѕ. Через Интернет 
запрос идет на веб-сервер, и в ответ на жесткий диск пользователя 
сыпятся: 


• файл іпаех.һіт, содержащий НТМІ (Нурег Техі Магкир Гапдиаде)-код с 
инкорпорированным в нем Јауа$сгірі (читается как "джава-скрипт")- 
кодом; 

• файлы-картинки (ітадеѕ), на которые ссылается веб-страница 
іпаех.һіт. Эти картинки пользователь должен увидеть в веб-брау- 
зере на веб-странице іпаех.һіт. 


Кстати, первая страница веб-сайта, которую мы по умолчанию видим 
в веб-браузере после набора ЦЕ веб-сайта (например, или. доодЕ.сот), 
называется һотераде. 


Кстати, коммуникация между веб-браузером и веб-сервером осуще- 
ствляется путем обмена сообщениями, основанными на протоколе, т.е. 
своде правил, называемом НТТР (Нурег ТехЕ Тгапѕїег Ргоюсо). Потоки 
таких сообщений, передающихся по компьютерной сети, называемой 
Интернетом, являются НТТР-трафиком (НТТР ігаїїс). 


2. Пользователь кликаетлинк "Регистрация" (веб-сервер присылает в 
ответ файл гедіѕїег.һіт и слинкованные с ним картинки). 


З. На странице гедіѕїег, һит пользователь вводит имя, е-мейл и прочие 
данные и отправляет форму, нажав кнопку "Зарегистрироваться". 
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4. Через веб-сервер эта форма, т.е. запрос о регистрации, поступает 
на сервер с приложением, которое 


• обрабатывает этот запрос; 

• запрашивает базу данных, есть ли уже эккаунт с таким е-мейлом; 

• обрабатывает ответ от базы данных; 

• если е-мейл не найден, посылает запрос к базе данных о созда- 
нии записи для нового пользователя; 

• формирует ответ для пользователя; 

• ввиде веб-страницы с подтверждением регистрации или веб-стра- 
ницы с ошибкой посылает пользователю ответ через веб-сервер. 


Так вот, программисты разрабатывают код вышеупомянутого 
приложения, который впоследствии отдается на растерзание тес- 
тировщикам, в злорадном предвкушении потирающим ручонки и 
знающим, что причинами возникновения багов в коде явля- 
ются как возможность программиста полдня бродить по Интер- 
нету, так и другие объективные вещи: 


а. Некачественные и/или изменяющиеся спецификации 
Об этом мы уже говорили. 

б. Личностные качества программиста 
Такие, как халатность, невнимательность и лень. 

в. Отсутствие опыта 


Программист может просто не знать, как нужно сделать пра- 
ВИЛЬНО. 


г. Пренебрежение стандартами кодирования 
О стандартах чуть позже. 
д. Сложность системы 


Современные интернет-проекты отличаются такой СЛОЖНОСТЬЮ, 
что мозг простого смертного порой просто не в состоянии про- 
анализировать все последствия создания/ изменения/ удаления 
кода и предугадать появление проблемы. 


е. Баги в ПО третьих лиц, т.е. баги 


• в операционных системах; 

• в компайлерах (сотрИег — ПО для переведения (напри- 
мер, С++) кода в машинный язык и создания исполняе- 
мых файлов); 

• в веб-серверах; 

• в базах данных и др. 
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ж. Отсутствие юнит-тестирования, 


х.е. тестирования кода самим программистом: "И вообще, почему 
я должен искать баги в своем коде, когда есть тестировщики?" 
(Поговорим о юнит-тестировании через минуту.) 


з. 


Нереально короткие сроки для разработки 


Об этом мы тоже скоро поговорим. 


Возможности оздоровления кода и превентирования багов до 
передачи кода тестировщикам (иллюстрации последуют не- 
медленно) включают: 


1. Наличие требований к содержанию спеков и следова- 
ние правилам их изменения; 

2. Возможность прямой, быстрой и эффективной комму- 
никации между программистами и программистами и 
продюсерами; 

3. Инспекции кода; 

4. Стандарты программирования; 

5. Реальные сроки; 

6. Доступность документации; 

7. Требования к проведению юнит-тестирования (о кото- 
ром мы поговорим уже через 30 секунд); 

8. Реальные финансовые рычаги стимуляции написания 
эффективного и "чистого" кода; 

9. Наличие понятий "качество" и "счастье пользователя" 
как основных составляющих корпоративной философии. 

Подробности. 


1. НАЛИЧИЕ ТРЕБОВАНИЙ К СОДЕРЖАНИЮ СПЕКОВ 
И СЛЕДОВАНИЕ ПРАВИЛАМ ИХ ИЗМЕНЕНИЯ 


О спеках мы уже говорили. 


2. ВОЗМОЖНОСТЬ ПРЯМОЙ, БЫСТРОЙ И ЭФФЕКТИВНОЙ 
КОММУНИКАЦИИ МЕЖДУ ПРОГРАММИСТАМИ 
И ПРОГРАММИСТАМИ И ПРОДЮСЕРАМИ 


Здесь есть следующие аспекты: 


а. Психологические аспекты 


Очень важно привить в культуру компании следующее правило: 


"Если к тебе обратились — помоги". 
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Пример 


Программист приходит к продюсеру с просьбой объяснить некую часть 
спека. Продюсер говорит, что он сейчас слишком занят. "Давай завтра, 
добро?" 

Очень часто после пары "давай завтра" программист что делает? Пра- 
вильно! Он пишет код так, как его понимает, — без всякой гарантии, что 
сей код отразит требуемое. 


Следующий аспект: 


программист (как и все остальные участники цикла) никогда не 
должен стесняться спрашивать (хоть двести раз!) и подтверждать 
свое понимание е-мейлами типа: "Просто хотел уточнить, что я 
правильно понял, что пункт 12.2 такого-то спека говорит..." Если 
же программисту не отвечают, когда он подходит, прекрасно — 
нужно послать е-мейл и сохранить этот е-мейл, как и е-мейлы "Я 
хотел уточнить". Если снова не отвечают, программист должен 
идти к своему менеджеру и просить его принять меры. И это не 
стукачество, а деловая практика — Риѕіпеѕѕ 15 Риѕіпеѕ5. 


Следующий аспект: 


Менеджмент должен регулярно устраивать так называемые Теат 
Вийаіпе Аспушеу (мероприятия по сплочению коллектива) с той 
простой целью, чтобы между членами команды кроме профес- 
сиональных налаживались и человеческие контакты. Причем, как 
показывает опыт, совместный выезд для игры в пейнтбол раз в 
месяц гораздо эффективнее для сплочения коллектива, чем со- 
вместная проспиртовка мозгов во время пятничных застолий. 


б. Технический аспект 


Каждый из участников цикла разработки ПО должен быть досту- 
пен для контакта: желательно, чтобы все они работали в одном 
здании; в локальной сети должны быть доступны служебные, мо- 
бильные и домашние телефоны; необходимо согласовать часы 
(хотя бы 4 часа в день), когда все (и тот, кто ушел в 6 часов вече- 
раив 3 утра) находятся в офисе. 


3. ИНСПЕКЦИИ КОДА 


У некоторых программистов есть такая концепция: "Если я пишу 
код, который могу понять только я, то меня не уволят". 


Ну, во-первых, при желании можно уволить даже президента 
"ЮКОСа", во-вторых, такой подход к работе априори неправи- 
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лен: в интернет-компаниях никто никого силком не держит, и 
если ты согласился работать на определенных условиях, то будь 
добр работать профессионально и добросовестно. 


Если же компания не выполняет взятых на себя обязательств 
(например, по оплате), то мы просто ищем другую компанию — 
ведь никто никому не давал клятву верности. 


Постановка мозгов 


Компания держит каждого из нас до тех пор, пока мы ей нужны, и если 
какая-то конкретная позиция перестает быть необходимой для бизне- 


са, то человеку просто говорят: "Гуд бай" независимо от того, сколько у 
него 

детей плачет по лавкам; 

котов мяукает по печкам. 
Как поет Тимур Шаов: "Это бизнес, господа..." 
Вместе с тем, если вы находите компанию с лучшими для себя усло- 
виями и, работая на старом месте, прошли интервью и получили 
письменное предложение о работе, то вы просто идете к своему ме- 
неджеру и говорите, что собрались уходить, но можете подумать о том, 


чтобы остаться, только если компания сделает для вас то-то и то-то, 
например повысит заработную плату. 


Несмотря на то что бизнес есть бизнес, нужно оставаться профессио- 
налом, даже если предложение о новой работе удивительно выгодно и 
искушение все бросить велико. Никогда не уходите из компании, не 
передав дела и не закончив старые проекты. Ведите себя про- 
фессионально ! 


После небольшого отступления продолжаем основную тему. 


В-третьих, чтобы избежать подобных проблем, чреватых багами 
и трудностью их фиксирования (йх — починка, ремонт), в ком- 
пании должны проходить инспекции кода (соде тзресйоп). 


Это может быть еженедельное совещание, например, следующего 
формата: менеджер программистов распечатывает код любого из 
программистов, и последний в присутствии коллег рассказывает, 
что, как и почему. Будет ли программист писать код, понятный 
только ему, если на совещании его обязательно спросят: "Това- 
рищ, а что это вы здесь написали?" 


4. СТАНДАРТЫ ПРОГРАММИРОВАНИЯ 


С пунктом 3 перекликается идея создания стандартов програм- 
мирования. 
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Пример 


Вспомним Вавилонскую башню, а вернее, тот момент строительства, 
когда все вдруг стали говорить на разных языках (множественность 
стандартов). Последствия печальны: проект был начисто заброшен, 
название кинокомедии "Ѕоте Ііке і һої" перевели как "В джазе только 
девушки" и японские фанатки "Тагу" убеждены, что "Мальчигей" — это 
название места для романтических свиданий нетрадиционных девушек 
на Красной площади. 


Такая же катавасия творится в компании, когда программисты 
вроде бы и используют тот же язык, например С++, но при напи- 
сании кода каждый руководствуется своими привычками. 


Пример 


Допустим, что отсутствуют стандарты названия новых классов С++. 
$ этом случае, если Саня любит называть свои классы в формате 
"СРЕРІТСАРР" (все заглавные и нижнее подчеркивание), а 

Леха — "Сге ЙСага" (заглавные только первые буквы каждого слова 
и слитное написание), 


то, например, Леха, не зная о привычках Сани, но верный своим при- 
вычкам, помня лишь "Кредиткард" и желая обратиться к функции из 
СРЕРІТСАКРР, в своем коде так и запишет: "СгеаїСага!". В итоге код не 
будет работать, так как С++, ничего не знающий ни о Лехе, ни о Сане, ни о 
кредитных картах, думает о СВҺЕРІТСАР” и СтеайСағ как об 
абсолютно разных классах. 


Стандарты могут включать: 


• правила о комментариях; 

• правила об именах таблиц в базе данных, классов, функций 
и различных видов переменных; 

• правила о максимальной длине строки; 

• прочее. 


Документ со стандартами должен быть доступен на интранете. 
Стандарты программирования — это неотъемлемая часть 


процесса, когда в компании работают два программиста и боль- 
ше. Они по определению должны быть обязательны для всех. 


5. РЕАЛЬНЫЕ СРОКИ 


В стартапе изначально и по определению сроки на разработку 
нереальны, и приходится балансировать между 

• "поспешишь — людей насмешишь" и 

• необходимостью закончить кодирование в срок. 
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Несмотря на то что стопроцентно действующих рецептов нет, вот 
хорошая идея для облегчения нелегкой жизни программистов: 


после ознакомления со спеками программисты должны предос- 
тавить менеджменту примерные оценки (сметы) сроков для 
разработки кода, и исходя из этих смет менеджмент может, 
если нужно 


• перераспределить нагрузку и 

посмотреть, имеет ли смысл убирать что-то из менее 
приоритетных функционалъностей ради того, чтобы 
чисто и тщательно написать остальной код. 


Единственное утешение состоит в том, что, когда стартап как 
бизнес становится более зрелым, сроки и рабочие часы стабили- 
зируются во многом потому, что менеджмент понимает, что луч- 
ше дать реальный срок (например, перенеся некоторые из спеков 
в следующие релизы), чем поступиться качеством. 


6. ДОСТУПНОСТЬ ДОКУМЕНТАЦИИ 


ВСЕ документы, относящиеся к разработке ПО, включая спеки, 
процедуру изменения спека, стандарты программирования, тест- 
комплекты, и документы, о которых мы будем говорить в даль- 
нейшем, должны быть доступны в локальной сети, и их располо- 
жение должно быть максимально оптимизировано для удобства и 
быстроты поиска. Все должно быть сделано для того, чтобы за- 
интересованный сотрудник быстро нашел нужный документ, а не 
тратил свое время и время своих коллег на долгие поиски. 


Несмотря на кажущуюся очевидность и легковесность этого мо- 
мента, несоблюдение правила о доступности ВСЕХ документов 
на практике может принести много проблем. 


7. ТРЕБОВАНИЯ 
КПРОВЕДЕНИЮ ЮНИТ-ТЕСТИРОВАНИЯ 


Юнит-тестирование (ипії іеѕіїпо) — это тестирование, произ- 
водимое самим программистом. Здесь нужно подчеркнуть, что 
неправильный подход к введению юнит-тестирования вызо- 
вет справедливое раздражение программистов, так как за тес- 
тирование платят тестировщикам, а отсутствие требований к 
юнит-тестированию вообще увеличит стоимость багов. 
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Постановка мозгов 
Стоимость бага — это 


• расходы компании, чтобы найти баг и исправить его до пе- 
редачи кода пользователю. Расходы компании поддаются 
приблизительной оценке; 

• убытки, которые несет компания, потому что баг не был 
найден до передачи кода пользователю. Объективная оценка 
убытков в большинстве случаев невозможна. 


Подробности: 


Стоимость бага в первом случае: 


Если баг был допущен на уровне спека и найден во время тестирования 
кода, его стоимость вычисляется как 


стоимость оплаты продюсера в час, помноженная на количество 
часов, потраченных на разработку "неправильной" части спека 
(стоимость спека), плюс + стоимость программирования 
"неправильной" части спека плюс + стоимость тестирования 
"неправильной" части спека плюс + стоимость фиксирования бага и 


проблем, из него вытекающих. 
Как видно, слагаемые поддаются приблизительной оценке. 


Стоимость бага во втором случае: 


Если баг был допущен на уровне спека, но не придушен до релиза и найден 
пользователем, то к стоимости, вычисляемой по формуле предыдущего 
случая, могут прибавиться десятки других убытков (включая упущенную 
выгоду), например: 


• время службы поддержки; 

• компенсации пользователю потерянных денег; 

• иски против компании; 

. навсегда утраченная потенциальная оплата услуг компании ушед- 
шими пользователями и пользователями, которые по рекомендации 
ушедших никогда не заглянут на ваш веб-сайт, 


а также множество других плохих и неприятных вещей. 


Наиболее важное в концепции стоимости бага — это то, что чем раньше 
будет найден баг, тем он будет дешевле для компании. 


Таким образом, баг (а это, как мы знаем, может быть и отклонение от 
здравого смысла), найденный на уровне идеи, — это самый дешевый 
баг, соответственно баг, найденный после релиза, — это самый 
дорогой баг. Причем убытки от последнего, как правило, не поддаются 
объективной оценке. 


Как видим, ЗА и тестирование — это не только обеспечение счастья 
пользователей, но и путь САМОСОХРАНЕНИЯ любой интернет- 
компании. 


Вернемся к юнит-тестированию. Вот две рекомендации: 


1. Юнит-тесты должны планироваться в письменной фор- 
ме ДО написания кода. 
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В таком случае программист после получения спека не бежит 
сломя голову писать код, а садится за документацию о дизайне 
кода с параллельным созданием юнит-тестов. 


Полезность такого подхода заключается в том, что, 


во-первых, программист абстрагируется от непосредственного 
кодирования и, видя "большую картину", может предугадать прин- 
ципиальные ошибки в алгоритмах и, 

во-вторых, он сможет заранее представить, КАК он будет тести- 
ровать код, это "КАК" занозой засядет у него в голове и при на- 
писании кода будет работать по принципу "предупрежден — зна- 
чит вооружен". 


2. Требования к юнит-тестам должны быть формализованы 
в стандартах о юнит-тестировании. 


Например, каждая функция должна иметь по крайней мере один 
тест-кейс с одним конкретным вводом и одним конкретным вы- 
водом (ожидаемым результатом). 


Принципиально, думаю, понятно. А так как написание и испол- 
нение юнит-тестов — это дело программистов, то мы закончим 
рассуждения о нем и пойдем дальше, у нас, тестировщиков, своих 
дел по горло. 


8. РЕАЛЬНЫЕ ФИНАНСОВЫЕ РЫЧАГИ 
СТИМУЛЯЦИИ НАПИСАНИЯ ЭФФЕКТИВНОГО И 
"ЧИСТОГО" КОДА 


Здесь все элементарно — менеджмент не должен жмотиться, если 
ЛЮДИ горбатятся на проект день и ночь, а в итоге не узнают своих 
подросших дет ей и называют своих жен Ленами (по имени колле- 
ГИ, сидящей за соседним компьютером и ставшей почти родной). 


» Хорошая заработная плата с возможностью увеличения; 
• билеты в "Ленком"; 

• премии за хорошую работу; 

• неограниченные чипсы и диет-кола; 

• оплата абонемента в бассейн и гимнастический зал; 

• месячные проездные; 

• выезды для игры в пейнтбол; 

• беспроцентный кредит на машину; 

• помощь при первоначальном взносе на квартиру — 
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чем больше заботы проявит компания о сотрудниках (и не только 
программистах), тем добросовестнее они будут работать, тем 
меньше будут получать втыков от жен — любительниц Гойи 
Ишшоп и тем больше будут радеть за свое место и качество кода, 
включая разработку дополнительных (от себя) юнит-тестов. 


В общем нужно сделать так, чтобы профессионал не думал о 
том, как свести концы с концами, а работал, зная, что его 
труд будет достойно оценен, и видел, что компания заботится 
о нем. 


9. НАЛИЧИЕ ПОНЯТИЙ "КАЧЕСТВО" И "СЧАСТЬЕ 
ПОЛЬЗОВАТЕЛЯ" КАК ОСНОВНЫХ СОСТАВЛЯЮЩИХ 
КОРПОРАТИВНОЙ ФИЛОСОФИИ 


Менеджмент должен сделать так, чтобы персонал понимал, что 
"качество" и "счастье пользователя" — это не фикция, а путь к 
финансовому успеху компании и соответственно лучшей жизни 
каждого, кто работает над проектом. Если менеджеры по- 
смеиваются над мерами по улучшению качества и отпускают 
шутки о пользователях (даже в курилке!), то это тлетворно 
действует на всех сотрудников компании и в конечном счете 
негативно скажется на пользователях, а следовательно, по 
принципу бумеранга и на самой компании, включая 
"юмористов". 


Пользователи знают, уважают их или нет, уже после одного 
сообщения об ошибке, одного е-мейла от компании или од- 
ного звонка в службу поддержки, и если философия компа- 
нии — это "тупые юзеры", то, поверьте, она проявится, на 
радость конкурентам, во многих вещах. 


Теперь поговорим о трех основных занятиях программиста: 


1. Написание кода для данного релиза происходит во время 
стадии "Кодирование". 


2. Интеграция кода для данного релиза происходит по за- 
вершении стадии "Кодирование". 


3. Ремонт багов для данного релиза происходит во время 
стадии "Кодирование" следующего витка цикла разработ- 
ки ПО (соответственно в пункте 1 программист ремонти- 
ровал баги для предыдущего релиза). 


Цикл разработки ПО 97 


Техническая версия 


1. НАПИСАНИЕ КОДА 


Один программист написал: рагепі уаіие = 1. Другой програм- 
мист написал: с^ уаіие = рагет уши + 3. 


2. ИНТЕГРАЦИЯ КОДА 


а. Пытаемся два куска кода соединить в один: 
рағепі уаше = 1, 
сһШа уаше = рагепт уши + 3. 


б. Код не компилируется (компайлер выдает ошибку о неоп 
ределенной переменной), так как второй программист на 
писал рагепі ущи вместо рагепі уаше. 

в. Код второго программиста фиксируется: 
сйИА_уаше —рағепі уаіие + 3. 


г. Пытаемся два куска кода соединить в один: 
рағепі уаше = 1, 
сһШа уаіие = рағепі уаіше + 3. 


д. Код компилируется, но первый программист выполняет 
юнит-тест, по которому рагепі уаше должно быть равно 7. 


е. Код первого программиста фиксируется: 
рағепі уаіие - І. 


ж. Пытаемся два куска кода соединить в один: 


рағепі уаіие = 7, 
сһШа уаіие = рағепі уаше + 3. 


З. Вроде все в порядке, передаем тестировщикам — пусть 
они тра... маются. 
3. РЕМОНТ БАГОВ 


Согласно спецификации должно быть: 


сћШа уаіие - рағепі уаіие х 3. 


Тестировщик рапортует баг, и на основании этого бага програм- 
мист меняет код. 
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Лирическая версия 


1. НАПИСАНИЕ КОДА 
О написании кода мы уже говорили. Один момент: 


Качество работы программиста не должно оцениваться по коли- 
честву багов, которые он взрастил, так как помимо таких субъек- 
ТИВНЫХ вещей, как профессионализм И добросовестность, на на- 
личие багов влияет множество других объективных факторов, о 
которых мы упоминали (нехватка времени, плохие спеки и т.д.). 


2. ИНТЕГРАЦИЯ КОДА 


Вариант 1. Неблагодарный 


После того как код написан на игровой площадке каждого из 
программистов, происходит интеграция кода, когда тысячи строк 
кода разных авторов компилируются на одном компьютере, на- 
езжают друг на друга, спотыкаются, огрызаются и дарят релиз- 
инженерам, производящим интеграцию, сомнения в принципи- 
альном наличии вселенской гармонии. 


Пример 
Собрали четырех отличных художников, причем каждый должен выпол- 
нить заказ на куске прозрачной пленки 50х50 см: 
• задание первому: нарисовать удрученного, стоящего на коленях 
молодого человека; 
• задание второму: нарисовать милостиво склонившегося старика; 
• задание третьему: нарисовать фон, вызывающий сострадание; 
• задание четвертому: нарисовать группу печальных людей. 


"В общем, парни, генеральная идея... эта... типа как у этого... О! У Рем- 
браНа: возвращение загулявшего сына". 
Неудивительно, что мы прочувствуем всю боль релиз-инженеров, ко- 
гда соединим четыре рисунка вместе и увидим 

• удрученного великана, стоящего на коленях над 

• стариком, 

• гладящим промокшую болонку 

• в окружении заспанных курсантов-суворовцев. 
Остается только редактировать картинки каждого из художников и гру- 
стить, что их не совмещали по мере написания, используя... 


Вариант 2. Благодарный 


Чтобы избежать проблем, когда в один момент происходит мас- 
сированная интеграция кодов разных авторов, как в Варианте 15 
программисты производят интеграцию постоянно по мере напи- 
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сания нового кода (т.е. стадия 1и стадия 2 цикла разработки кода 
сливаются в одну стадию), что дает возможность выявить несты- 
ковки между кодами разных авторов на раннем этапе. 


3. РЕМОНТ БАГОВ... 


происходит во время стадии "Тестирование и ремонт багов", по- 
сле того как код для данного релиза был заморожен и програм- 
мисты работают над кодом для нового релиза. 


Необходимость в замораживании кода вызвана тем, что продукт 
(в данном случае код) должен быть в каком-то устойчивом виде, 
чтобы его проверили. 


Пример 
Представьте следующую ситуацию: 


1. Программист закончил работу над функциональностью А; 

2. Тестировщик проверил, что функциональность А работает, и дал 
добро на релиз; 

3. За час до релиза программист вносит маленькое изменение в код, 
которое в теории ничего не ломает... 


а на практике приводит к тому, что функциональность В, связанная с А, 
абсолютно перестает работать, т.е. получилось так, что тестировщик 
попросту потерял время (а значит, и деньги компании), тестируя не 
финальную версию продукта. 


Из сказанного вытекают две принципиально важные для тести- 
ровщика вещи. Перед началом тестирования нужно убедиться, что 


• код заморожен (обычно релиз-инженеры посылают соот- 
ветствующий е-мейл); 

• версия продукта на внутреннем сайте, на котором вы будете 
производить тестирование, является именно той версией, 
которую вам нужно протестировать. 


Пример 
Допустим, что на интранете у нас есть два внутренних тестировочных 
веб-сайта, недоступных для пользователей: 


• ими. еуегез е$15Пор.г$ и 
._ иму.е/бгиѕ.іеѕіѕһор.гѕ 


Допустим также, что сайт 


._ ими. еуегез е$15Пор.гз(по-простомуназываемый "Эверест") является 
версией 1.0 и содержит функциональность А версии 1.0, а 

._ имм.е/бгиѕ.іеѕіѕһор.гѕ(по-простомуназываемый "Эльбрус") является 
версией 2.0 и содержит функциональность А версии 2.0. 
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Так вот в окне веб-браузера функциональность А может выглядеть аб- 
солютно одинаково и на Эвересте, и на Эльбрусе, но ее бэк-энд будет 
существенно различаться на этих двух сайтах. 


Допустим, тестировщик собирается проверить функциональность А 
версии 2.0, но ошибочно использует для тестирования Эверест (с вер- 
сией 1.0), вследствие чего он не только впустую тратит время, но 
и рискует дать добро на релиз непротестированного кода функцио- 
нальности А версии 2.0. 


Подобные ошибки возникают, как правило, по небрежности или 
незнанию тестировщика и из-за "нелогичных" названий внутрен- 
них веб-сайтов. 


Пути предотвращения ситуации, когда тестировщик тестирует не 
ту версию ПО: 


1. Узнайте у релиз-инженера, как определить версию кода, и 
используйте сие знание перед началом исполнения тести- 
рования; 


2. Посоветуйте, чтобы внутренние веб-сайты имели логич- 
ные имена. Например, версия кода, переданного пользова- 
телю, всегда должна быть на внутреннем сайте по адресу 
ууу. 014 .1еѕіѕћор.тѕ, а версия для следующего релиза — на 
уму. тат4ез15йор.ту; 


3. Попросите релиз-инженеров, чтобы те создали на интра- 
нете динамически обновляемую страничку с информацией 
о 


• версии и 
• подверсии, т.е. билде (об этом позже), 


каждого внутреннего тестировочного веб-сайта. 


В завершение кодирования поговорим еще о паре вещей. 


Хотя и спеки, а иногда даже и сами идеи для спеков — ребятки 
не без греха, большинство багов зачинается именно при написа- 
нии кода. При кодировании появляется присущий только этой 
стадии и одновременно самый простой в нахождении вид бага — 
синтаксический баг (ѕупіах Био). 


Прелесть синтаксических багов заключается в том, что они, явля- 
ясь ошибками в языке программирования, находятся компай- 
лером (например, в случае с С++) автоматически. Последний 
выдает на экран сообщение об ошибке и принципиально не соз- 
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дает исполняемый файл, пока проблема не будет зафиксирована 
(в скриптовых языках, таких, как Руѓлоп, исполняемым файлом 
является сам файл с кодом и синтаксические баги находит интер- 
претатор языка). 


Пример 
Вот первая программка любого изучающего С++: 


1. нпсиае <іоѕігеат.һ> 2. 
3. уоіатаіп() 


Б соиі<< "Нео, И/опа!<< епа; 


6.) 


Текст этой программки находится в файле ѕупѓах егғог.срр. По- 
пробуем ее скомпилировать: 


=> С++ ѕупіах еггог, срр 
5ушах_еггог.срр:5: ишегттееа утих ог сһагасіег сопѕіапі 
ѕупіахегғоғ.срр: 5: роѕѕіЫе геа! зат оў ипіегтіпаѓей сопѕїапі 


Последние две строчки — это текст об ошибке, выданный ком- 
пайлером из-за того, что мы не закрыли кавычки в строке 5 после 
Ио"! Никакого исполняемого файла создано не было. Если мы 
исправим эту ошибку, то файл без проблем скомпилируется. 


Тестировщики обязаны устройству Вселенной за то, что есть ло- 
гические баги (Јосіса! Биз5). Эти баги, как следует из их назва- 
ния, — это ошибки в логике кода, т.е. код компилируется без син- 
таксических ошибок, но фактический результат исполнения этого 
кода не соответствует ожидаемому результату. 


Пример 
Спецификация: 


"7.2. Пользователь должен ввести два целых числа от 1 до 12, 
после чего программа выведет на экран их среднее арифмети- 
ческое". 


Код: 


1. #іпсіиде <іоѕігеат.һ> 2. 


уоіатаіп() 


ГА 
1 


3 

4. 

5. ТЕНГЕ питбег = 0; 

6. іп ѕесопајпитбег = 0; 
7. Поаі ауегаде = 0.0; 
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8. 
9. //9еї Їїгѕї питбег 
10. сои "Епіег їгѕї питбег:"; 
11. сіп » ШЗЕ п итбег; 
12. 
13. 
14. //деЕ ѕесопа питрег 
15. соиі« "Ещег ѕесопа питрег:"; 
16. сіп » зесопа питбег; 17. 
18. /сасшаЕ ауегаде 
19. ауегаде = їгѕ}уіитбег+ѕесопа питрег2.0; 20. 
21. /юшриЁ гезий 
22. соиї« "Ауегаде = "« ауегаде « епа!/; 23. 
24. } 


Тестирование: 


Епіег їїгѕї питрег: 9 Ещег 
ѕесопа питбег: 2 Ауегаде 
=10 


Согласно спецификации результатом исполнения программы 
должно быть среднее арифметическое двух чисел, т.е. в нашем 
случае 5,5 (ожидаемый результат). Фактический же результат 
оказался равен 10. 


9,5 


не равно 10, соответственно у нас есть логический баг. 


Проблема, кстати, в строке 19, которая должна была звучать так 
(были пропущены скобки): 


19. ауегаде = (їїгѕі питБег+ѕесопа питбет)/2.0. 


Кстати, в приведенном пункте спека есть баг, так как непонятно, какое 
максимально допустимое целое число: 11 или 12? Программист, увидев 
этот баг, должен был сделать уточнение у продюсера и обязать того 
исправить спек. Если максимальное число = 12, то точная формулировка 
должна быть следующей: "7.2. Пользователь должен ввести два целых 
числа от 1 до 12 включительно, после чего программа выведет на экран 
их среднее арифметическое". 


Кстати, программист заложил в коде еще один логический баг, так как 
согласно спеку код должен принять только действительный ввод, кото- 
рым являются целые числа 1— 11 (или 1 — 12). 


Кстати, спек имеет еще один баг: не сказано, как должна отреагировать 
программа, если пользователь введет недействительный ввод, например 
0, 13, "А", "#" или пустое место... 
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Две последние вещи в разговоре о стадии кодирования. 


Первая вещь 


Как мы помним, на этой стадии тестировщики пишут тест-кейсы. 
Так вот тест-комплекты необходимо, как и спеки, хранить в СУ$ 
и публиковать линки к ним на интранете для предоставления 
возможности свободного ознакомления с ними любому заинтере- 
сованному лицу внутри компании. Главные преимущества хране- 
ния тест-кейсов в СУ: 


• отсутствие возможности случайного удаления файла; 

• присутствие возможности возвратиться к предыдущим вер- 
сиям файла; 

• файл хранится на сервере, и каждый, кому нужно (и кто 
имеет право), может взять его для исполнения тестирова- 
ния, изменения и удаления существующих или включения 
дополнительных тест-кейсов. 


Вторая вещь 


Хорошая идея для компании в целом и для интересов самого 
тестировщика — это провести рассмотрение тест-кейсов (Теѕ/- 
саѕе Кемем»), когда за несколько дней до начала тестирования со- 
бираются 


• продюсер, написавший спек, 
• программист, написавший по спеку код и 
• тестировщик, написавший по спеку тест-кейсы. 


Тестировщик раздает присутствующим распечатки этих тест-кей- 
сов и подробно рассказывает, как он будет проверять функцио- 
нальности, описанные в спеке. 


Полезность рассмотрения тест-кейсов заключается в том, что 
во многих случаях продюсеры и программисты дают новые 
идеи для тестирования и/или корректируют допущенные не- 
точности. 


Политический момент 
Если участники митинга 


• не предложили внести в тест-кейсы ничего нового либо 
• предложили и вы внесли, 
то это формально означает, что они одобрили то, как будет протести- 


рован код. А так как все протестировать невозможно и всегда есть веро- 
ятность, что мы не проверим какой-либо багосодержащий сценарий, 
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то даже в случае пропущенного бага все будут знать, что вы сделали 
все возможное для качественной подготовки к тестированию, т.е. соз- 
дали тест-кейсы и получили одобрение их эффективности. 


Кстати, после рассмотрения тест-кейсов пошлите е-мейл всем 
присутствовавшим на совещании. Перечислите в этом е-мейле все 
модификации к тест-кейсам, о которых вы договорились на совеща- 
нии. Таким образом, с одной стороны, вы составите памятку для са- 
мого себя, а с другой — дадите себе возможность удостовериться (пу- 
тем получения ответов на е-мейл), что вы учли все предложенные вам 
вещи по модификации тест-кейсов и учли эти вещи правильно. Отсут- 
ствие ответа на подобный е-мейл — это знак согласия. 


Во многих крупных интернет-компаниях рассмотрение тест-кей- 
сов — это обязательная процедура перед переходом к стадии... 


Исполнение тестирования и ремонт багов 


Так как о тестировании мы будем говорить все остальные томные 
вечера, то сейчас будем лаконичны, как спартанцы. 


После того как проинтегрирован код, тестировщики проводят 
тест приемки (5токе іеѕі, ѕапіїу іеѕі или соппаепсе 1е51), в процессе 
которого проверяются основные функциональности. 


Пример 


Если мы не можем погнуться (109 тю) в наш эккаунт (ассоип) на 
или. таіп.іеѕіѕһор.гѕ, то о каком дальнейшем тестировании можно 
говорить. 


Если тест приемки не пройден, то программисты и релиз-инже- 
неры совместно работают над поиском причины. Если проблема 
была в коде, то код ремонтируется, интегрируется и над ним сно- 
ва производится тест приемки. И так по кругу, пока тест приемки 
не будет пройден. 


Если же тест приемки пройден, то код замораживается и тести- 
ровщики начинают тестирование новых компонентов (пез? /еа- 
іште іеѕііпе), т.е. исполнение своих тест-кейсов, написанных по 
спекам данного релиза (более подробно о значении термина јеа- 
іште поговорим в беседе о системе трэкинга багов). 


После того как новые функциональности протестированы, насту- 
пает очередь исполнения "старых" тест-кейсов. Этот процесс на- 
зывается регрессивным тестированием (гестеѕѕіоп (езИпв), ко- 
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торое проводится для того, чтобы удостовериться, что компонен- 
ты ПО, которые работали раньше, все еще работают. 


Баги заносятся в систему трэкинга багов (Вис Туаскіпе $уѕіет, 
далее — СТБ, о ней у нас будет отдельный разговор), программи- 
сты их ремонтируют, и затем тестировщики проверяют, насколь- 
ко качественным был ремонт. 


Допустим, мы все, что хотели и как смогли, протестировали. Про- 
граммисты залатали дыры в коде, что мы тоже протестировали, и 
у нас есть версия нашего проекта, готовая для релиза. Эту версию 
мы мурыжим еще пару деньков, проводя тест сдачи (Ассеріапсе 
ог Сегийсайоп Тез), и включаем зеленый свет релиз-инженерам, 
чтобы они передали плод наших терзаний кликам (от англ. с/їс[) 
пользователей. 


Релиз 


Ке[еаде (англ.) — "выпуск, освобождение". 


Пример 


Герой романа Стивена Кинга — ботаник, чудик и домосед — подверга- 
ется постоянным унижениям от одноклассников, домочадцев и случай- 
ных прохожих. В один день он вдруг говорит себе "Хватит" и начинает 
колоть, резать и душить подлых обидчиков, а также в превентивных 
целях и всех остальных. Этот выпуск пара и есть "релиз" в его обыден- 
ном понимании. 


До этого мы употребляли слово "релиз" в значении "основной 
релиз" (так будем поступать и дальше), но у нас есть и его "род- 
ственники". 


Вот полная классификация "релизообразных": 


1. Релиз (он же основной релиз) (татог геіеаѕе) — стадия в 
цикле разработки ПО, идущая за стадией тестирование и 
ремонт багов, т.е. передача пользователям кода новой вер- 
сии нашего ПО. Как правило, обозначается целыми 
числами, например 7.0. 


2. Дополнительный релиз (тіпог ғеіеаѕе) — ситуация, когда 
после основного релиза планово выпускается новая функ- 
циональность или изменяется/удаляется старая. Дополни- 
тельный релиз не связан в багами. Как правило, 
обозначается десятыми, например 7.1. 
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3. Заплаточный релиз (рейсй ге[еахе), когда после обнаруже- 
ния и ремонта бага выпускается исправленный код. Как 
правило, обозначается сотыми, например 7.11. 


О чем говорит версия 12.46 нашего ууру. ѓеѕіѕйор.г5? А говорит 
она о трех вещах: 


1) отом, что последний основной релиз является двенадца- 
тым по счету; 

2) о четырех дополнительных релизах, выпущенных ПОСЛЕ 
двенадцатого релиза; 

3) о шести заплаточных релизах, выпущенных ПОСЛЕ две- 
надцатого релиза. 


Кстати, о номерах релизов. Некоторые компании в желании поориги- 
нальничать дают основным релизам не номера, а названия. Ну, напри- 
мер, имя поп-группы или отдельного исполнителя. 


Звонит программисту дружок: 

— Здорово, старик. Слушай, Ленка подружку приводит, так что бери 
шампанское и подъезжай к семи. 

— НЕ, я пас. Я тут с "Бритни Спирс" завис. - 

О!.. 


Неудобство такого подхода заключается в том, что непонятно, какой 
релиз был раньше — "Пол Маккартни" или "Джон Леннон", и в идиотиз- 
ме произнесения названий дополнительных или заплаточных релизов: 
звонит контрагент со своей проблемой, а ему говорят: "Да усе будет в 
порядке. Мы заутра патч номер 7 кДорз присобачим". 


Идем дальше. 


Любой из трех релизов для пользователя означает, что наш 
уиуу. 4ез15йор.ту как-то изменился. 


Возможные изменения: 


1. Новые функциональности (основной и дополнительный 
релизы); 

2. Изменение/удаление старых функциональностей (основ- 
ной и дополнительный релизы); 

3. Починка багов, пропущенных в одном из релизов любого 
типа (заплаточный релиз). 


Организация упаковки кода в виртуальный мешок и его передача 
пользователю осуществляются релиз-инженерами. 


Давайте представим, что ЗАО "Тест-шоп", предназначенное, 
кстати, для продажи книг, только начинает работу. 
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У нас есть 


• два программиста (Дима и Митя) и 
• хозяин-барин (месье Кукушкин Илья Харитонович), 


а также 


• два компьютера с "Виндоуз" для программистов (здесь и 
далее я не буду давать версий не нашего ПО), 

• клевый лэптоп Харитоныча (ОС значения не имеет) и 

• машина с Линуксом (далее называемая тест-машина) для 
разработки и тестирования ПО. 


Проект начинается: 


1. Регистрируется домен ууу. ѓеѕіѕйор. г. 

2. У интернет-провайдера и по совместительству хостинг-про- 
вайдера покупается доступ в Интернет и арендуется сервер, 
чтобы весь мир мог зайти на огонек, увидеть и оценить. 

3. Программистские компьютеры, лэптоп СЕО и тест-машина 
объединяются в локальную сеть с выходом в Интернет. 

4. Программисты начинают работать над проектом. 


Мы уже говорили о том, что классическая архитектура веб-про- 
екта — это 

. веб-сервер; 

• сервер с приложением; 

• база данных. 


Так вот, так как мы — интернет-компания молодая, то у нас все 
будет по-простому: на тест-машине будут все три компонента. 


Архитектура иуи. ѓеѕіѕйор.гѕ 


1. Веб-сервер Арасйе ("апачи", имя которого идет не от названия 
американского племени индейцев, издревле промышлявших под- 
работками на интернет-проектах, а от расйу (залатанный), как 
память о неимоверном количестве заплаток, на него приклеен- 
ных, в результате чего он приобрел белизну и пушистость). 


В директориях Арасйе мы храним: 


• файлы, содержащие НТМГ-код С инкорпорированным 
Јауа$сгірі-кодом. Јауа$сгірі-код, вставляется в НТМГ.- 
файлы и может служить, например, для проверки е-мейла 
при регистрации на наличие двух @. Достоинство 
использования .Јауа$сгірі-кода, заключается в том, что 
проверка осуществ- 
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ляется на компьютере пользователя в отличие от варианта, 
когда мы посылаем непроверенную форму с регистрацией 
на сервер с приложением, нагружая этот сервер; 
файлы-картинки (йпасезѕ). 


2. Приложение на Руѓлоп и С++. Наше приложение состоит из: 


файлов с Руһоп-скриптами, которые можно использовать, 
например, для "перевода" регистрационной формы, от- 
правленной пользователем, на язык, понятный базе дан- 
ных, и для создания новой строки в таблице для новых 
пользователей; 

файлов с С++ кодом. Например, нам нужно вставить новое 
значение в определенной колонке определенной таблицы 
базы данных для всех пользователей, зарегистрированных 
у нас более 1 года. Для этой цели мы можем написать про- 
грамму на С++. 


Кстати, С++ файлы — это единственные файлы в нашем проекте, 
которые мы компилируем перед использованием: каждый из наших 
С++ файлов — это простой текстовый файл с кодом, написанным на С++, 
и, чтобы он стал исполняемым, его нужно скормить С++ компайлеру, 
который проверит код на наличие багов синтаксиса и, если все Ок, 
переведет язык, понятный человеку (С++), на язык, понятный тест-ма- 
шине (нули и единицы). 


3. База данных МубОГ ("майсиквел"). Здесь мы будем хранить 
данные 


о пользователях (например, день регистрации в системе, е- 
мейл, имя, фамилию и пароль); 

о транзакциях пользователя (например, когда и что купил); 
о наименованиях книг и их наличии. 


Идем дальше. 


Начинаются первые неудобства И проблемы, связанные с отсут- 
ствием релиз-инженерных знаний: 


1. 


При каждом сохранении файла в той же директории нужно 
давать ему новое имя, чтобы не удалить старый вариант 
редакции. 

При сохранении файла после редактирования нельзя про- 
комментировать, что было изменено. 

Самое главное: постоянно присутствует риск, что один из 
программистов удалит свою работу или работу коллеги. 
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Пример 


а. 


б. 


После спецификации, пробормоченнои Харитонычем за рюмочкой 
чая, программисты начинают писать код. 

Частью кода является файл гедіѕігайіоп.ру, который лежит в ди 
ректории /иѕгЛоса/арасһе/сдјі-Біп/ и был написан Димой два дня 
назад. 

Дима копирует этот файл в свою директорию /поте/ата и начи 
нает его редактировать. 

Одновременно с ним без всякого злого умысла этот же файл копи 
рует и сохраняет в своей директории (/поте/тйуа) Митя и тоже на 
чинает его редактировать. 

Дима, дописав и протестировав гедіѕігаїіоп.ру, переносит (тоуе) 
его обратно в /изТосаГараспе/саНЫт,. 

Вслед за ним туда же переносит свою версию гедіѕігаїйоп.ру и Митя, 
в результате чего: 


• в /иѕгЛоса[/арасһе/сді-Біп/ лежит Митина редакция; 

• Дима рвет на себе волосы, так как не сохранил у себя ни копии 
первоначального файла, ни файла с новым кодом; 

• Митя рвет на себе волосы, так как в процессе разработки у него 
была работающая версия, но он ее не сохранил, а, решив, что 
другой алгоритм будет лучше, написал другую версию, которую, 
толком не протестировае, перенес в /иѕгЛоса/арасһе/сді-Біп/. 

• первый релиз откладывается, так как Митина версия гедіѕіга- 
йоп.ру абсолютно "не пашет". 


осле разбора полетов принимается решение об установке СУБ. 


М5 устанавливается на тест-машину и это дает следующее: 


Файлы хранятся в репозитарии (ғероѕіїоғу), 
ОТКУДА 


их можно взять для редактирования (слескои?) и 


КУДА 


их можно положить после редактирования (сйес®т). 


При этом 


а) каждый раз, когда мы кладем файл в репозитарии, 


• не нужно менять имени файла; 

• мы можем комментировать, что было изменено в этом 
файле; 

• СҮ автоматически присваивает файлу номер редакции 
(версии), уникальный для этого файла; 

» СҮ связывает номер версии файла, комментарий к из- 
менениям, имя изменившего и время изменения в одну 
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запись (при желании можно увидеть всю историческую 
последовательность записей); 


6) если Дима взял из репозитария файл, то Митя не может его 
оттуда взять, пока Дима не положит его обратно. 


Итак, поставив старую добрую и бесплатную СУ5, мы имеем: 


• все версии файла, каждая из которых кроме уникального 
номера версии имеет еще и запись об изменениях; 

. программистов, которые уже не могут случайно уничто- 
жить код друг друга; 

• возможность сравнить содержание файла в разных ре- 
дакциях. 


Теперь, когда наш код хранится в СТ5, возникает другая задача — 
как сделать так, чтобы этот код стал доступным на веб-сайте для 
тестирования — уиуу. тат 4ейор.т5? Для решения этой задачи 
нужно, чтобы файлы из СУ$ были интегрированы и отправлены 
по назначению в соответствующие директории тест-машины и 
чтобы у нас было отражение содержимого СИ$ 


• по состоянию на данный момент и 
• для данного релиза. 


Каждое такое отражение кода веб-сайта называется билдом (Ри!/а). 
Иными словами, билд — это версия версии ПО. 


Билды делаются или вручную, или путем запуска билд-скриптов 
(Рийа ѕсғірі), т.е. программ, написанных релиз-инженерами для 
автоматизации процесса. Как правило, билд-скрипты добавляются 
в сгоп (это расписание запуска программ в Линукс-системах), с 
тем чтобы создавать новые билды через определенные проме- 
жутки времени. 


Цель создания новых билдов заключается в том, чтобы изме- 
ненный код (сохраненный в СУ) стал доступным для тестиров- 
ЩИКОВ: 


а. После того как программист починил баг, найденный при 
тестировании, он тестирует починку на своем плэйгра- 
унде, после чего делает сйесќіп отремонтированного кода 
в С/5. 

б. Отремонтированный код становится частью нового билда. 

в. Новый билд замещает (ғер/асе) на тест-машине код преды 
дущего билда. 
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Пример 


Допустим, что время на создание нового билда равно 15 минутам. 
Билд-скрипты создают новые билды каждые 3 часа в соответствии с 
расписанием билдов (Бийа зспедиЕ): в 12:00, 15:00, 18:00 и т.д. Прак- 
тическую ценность здесь имеют две вещи: 


1. Нет смысла тестировать веб-сайт с 12:00 до 12:15, с 15:00 до 
15:15, с 18:00 до 18:15 и т.д., так как билд находится в процессе 
создания и одна часть файлов может принадлежать старому 
билду, а другая — новому. 

2. Если программист починил ваш баг и сделал сһескіп изменен- 
ного кода в СМ$, то вы сможете протестировать починку только 
после следующего билда, т.е. если сһескіп файла в С\У$ произо- 
шел в 16:00, то протестировать починку можно после билда, ко- 
торый начнется в 18:00. 


Соответственно иногда в целях экономии времени имеет смысл 
попросить релиз-инженера, чтобы тот сделал внеочередной билд, 
причем о последнем должны быть оповещены все остальные тести- 
ровщики. 


Итак, перед проверкой починки бага убедитесь не только в 
том, что вы тестируете нужную версию, но и в том, что тести- 
руете нужный билд. Номер билда, содержащего отремонтиро- 
ванный код, включается программистом в запись о баге в СТБ 
(подробнее об этом в разговоре о СТБ). 


Кстати, номера билда для данной конкретной версии начинаются с 
единицы для первого билда (который мы проверяем во время теста 
приемки) и увеличиваются на единицу с каждым новым билдом. 


Как узнать номер билда? Спросите об этом своего релиз-инже- 
нера. В веб-проектах номер билда часто включается в НТМІ-КОЈХ 
каждой страницы веб-сайта и может быть найден, если посмотреть 
этот код, используя функциональность веб-браузера Иїеу ѕоигсе. 


Итак, Дима написал билд-скрипт, добавил его в сгоп, и новый 
билд у нас создается каждые 3 часа. 


С точки зрения конфигурации системы плэйграунд каждого из 
программистов находится на той же тест-машине. 


Дело в том, что на одном веб-сервере могут находиться сразу не- 
сколько веб-сайтов. В нашем случае: 


• ими. тійуа.іеѕіѕһор.тѕ — это адрес Митиного плэйграунда, 

• ууу. іта .іеѕіѕћор.ғ5 — это адрес Диминого плэйграунда, а 

• ууу. таїп.іеѕіѕһор.тѕ — это веб-сайт, на который делается 
каждый из билдов. 
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Следовательно, тестировщики будут использовать именно 
ууу. таїп.іеѕіѕһор.тѕ для своего тестирования. 


Соответствующие 


• директория с ЯГЖ-файлами и картинками, 
• директория с приложением (Руйоп и С++ файлы) и 
• база данных 


слинкованы с каждым из сайтов, так что у нас есть три конфигу- 
рации, независимые друг от друга. 


Кстати, важный нюанс о плэйграундах, билдах и СУ$. Основное правило 
для сһескіп: сначала сделай быстрый юнит-тест и убедись, что твои 
файлы компилируются по крайней мере на твоем плэйграунде, 
и уже после этого делай их "публичными" через сһескіп е СМ. 


Рациональное объяснение: билды строятся из кода, хранимого в 
Су. Если же код не компилируется, то билд будет сломан (Бийа 
15 Ртокеп) и соответственно никакого тестирования не будет. 
Мы касались этого правила, говоря об идее постоянной интегра- 
ции кода. 


Идем дальше. 


Код написан, тестирование и ремонт багов закончены. Настало 
время первого релиза ууу. ѓеѕіѕйор.т!!! 


Первый релиз происходит так: 


1. Подготовка машины у хостинг-провайдера (ргодисіїоп 
ѕегует, просто ргойисіоп или Пуе тасћіпе — машина для пользо- 
вателей). 


Когда говорили об аренде сервера хостинг-провайдера, то име- 
лось в виду, что мы арендовали совершенно конкретный компью- 
тер, который находится где-то у провайдера и имеет уникальное 
(в общемировом масштабе) сетевое /2, которое называется /Р 
Ааагеѕѕ ("ай-пи адрес"). Используя этот ІР Аа4геѕѕ, мы подсое- 
диняемся к этой машине и настраиваем 


а) провайдерский Линукс (например, создаем директории, 
редактируем разрешения и т.д.); 

б) провайдерский Арасће (например, вносим изменения в 
файл конфигурации и т.д.); 

в) провайдерскую МубОГ (например, определяем максималь 
ное количество соединений и т.д.). 
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2. Подготовка релиз-скрипта (7е/еаѕе стр) — программы, кото- 
рая автоматизирует процесс релиза на машину для пользователей. 


3. Исполнение релиз-скрипта: 


а) релиз-скрипт запускает билд-скрипт, чтобы на тест-маши 
не создался новый билд; 

б) релиз-скрипт берет файлы этого нового билда и по прото 
колу ЕТР ("эф-ти-пи" — Ее Тғапѕјег Ргоюсой пересылает 
их в машину для пользователей; 

в) релиз-скрипт: 


• копирует из СУ$ на машину для пользователя скрипты 
для базы данных (ОВ-ѕсгіріѕ) и 
• запускает эти скрипты. 


Скрипты ДЛЯ базы данных создают или модифицируют схему 
базы данных. Так как у нас первый релиз, то схема базы данных 
только создается, а именно создаются три таблицы: 


• иѕег іпјо (для данных о пользователях); 
• изег тапзаспоп (для данных о транзакциях пользователя); 
• БооК уаий (для данных о наименованиях книг и их наличии). 


Кстати, нужно различать 


• схему базы данных (даќабаѕе, или просто ОВ, ѕсһета) и 
• сами данные. 


Схема базы данных — это совокупность виртуальных контейнеров 
(над БД работают программисты и администраторы БД). 


Данные — это начинка этих виртуальных контейнеров, которую своими 
действиями на иммм4е$5Рор.гз, например регистрацией, создают/из- 
меняют пользователи (изег_тЮ и иѕег {гапзасйоп) или другие лица 
(например, Харитоныч, который через специальную программу, напи- 
санную Митей, может добавить новые названия книг и их количество 
в Боок умаи). 


Небольшое отступление 


По мере развития проекта машина для пользователей превратится в 
десятки связанных между собой веб-серверов, серверов с приложением 
и серверов с базами данных, образующих ргоаисіоп роо, т.е. сово- 
купность компьютеров, обслуживающих наших пользователей. Но это 
будет потом. А пока... 


Й’есоте іо им’ лез5йор.г5!!! Наш первый релиз состоялся!!! 


Книги продаются, к проекту примкнули кореша Харитоныча, в 
результате чего появились деньги, чтобы нанять новых людей и 
вообще начать активно расширяться. 
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Над проектом уже работают 2 продюсера, 7 программистов и 1 
тестировщик. Долго ли, коротко ли, а уже и второй релиз (версия 
2.0) состоялся. 


На следующий день после выпуска версии 2.0 лавина жалоб от поль- 
зователей дает основания полагать, что версия 2.0 ууу. ѓеѕіѕйор. 5 
так же насыщена багами, как версия-2004 Государственной думы 
единороссами. 


Компания превращается в форпост по борьбе с последствиями 
релиза версии 2.0: 


месье Кукушкин носится между столами программистов 
и тестировщика, давая ценные указания и оперируя сло- 
варным запасом, приобретенным на раннем (колымском) 
этапе своей карьеры; 

программисты, которые не чинят баги версии 2.0, не мо- 
гут сохранить файлы для версии 3.0 в СУ5, так как в СУ5 
решением руководства можно сохранять только код с от- 
ремонтированными багами для релиза 2.0; 

программисты, которые чинят баги, естественно, не мо- 
гут работать над версией 3.0; 

тестировщик проверяет отремонтированный код для вер- 
сии 2.0 вместо подготовки к тестированию версии 3.0; 
продюсеры отвечают на е-мейлы разгневанных пользова- 
телей, которые, несмотря на биографии менее яркие, чем 
биография Харитоныча, тем не менее с легкостью опери- 
руют тем же словарным запасом. 


Кстати, справедливости ради стоит отметить, что по идее к версии 1.0 
вернуться можно, но это займет время и чревато ошибками, так как 
основной объем работы будет делаться вручную. Понадобится: 


• найти версии файлов в С\У$ на день первого релиза*, 

• изменить и протестировать билд- и релиз-скрипты, 

• запустить релиз-скрипты и проверить, насколько правильно они 
сработали. 


• Если в первом релизе у нас были десятки файлов, то с течением времени 
их будут сотни!!! 


В таком бедламе проходит двое безвылазных суток, и наконец 
баги придушены, билд протестирован на тест-машине и срочно 
организуется патч-релиз 2.01 на машину для пользователей. 


После разбора полетов Митей, как одним из старожилов компа- 
нии, вносится предложение о создании бранчей (Бгаисй — ветвь) 
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в СУ5. Предложение принимается единогласно (тем более что от- 
вечать в случае провала будет инициатор), и Митя рассказывает, 
в чем суть этого подхода. 


РАССКАЗ МИТИ 


'В общем так, други. Допустим, у нас есть ребенок и его фото- 
графии нужно раз в месяц по е-мейлу посылать теще. Если при- 
сылается фотография ребенка в недовольном состоянии, то теща 
приезжает и устраивает дома такой шухер, как будто она по- 
пользовалась нашей версией 2.0. Соответственно нужно сохранить 
фотографию ребенка, когда он улыбается, и если новая фото- 
графия теще не нравится, то нужно просто послать ей старую 
фотографию с улыбкой и сказать, что ошибка вышла". 


Харитоныч: 


— Да вот я помню... (далее следует 30-минутный рассказ о его 
тещах с постепенным переходом к обобщениям и, наконец, дек- 
ларативному изложению отношения ко всему прекрасному полу). 
Да-а-а, вот так-то. Что ты там говорил про версию 2.0? 


ПРОДОЛЖЕНИЕ МИТИНОГО РАССКАЗА 


«Да, вот. Как я и говорил о хорошем и улыбающемся билде. Вот 
мини-история нашего проекта со стороны релиз-инженера: 


В один прекрасный день мы начали работать над кодом ПО, и по 
мере написания этого кода стали добавлять в СУ$ новые файлы 
‚и изменять файлы, уже существующие в ней. В определенный 
момент мы сказали "Стоп" и назвали совокупность файлов в 
СҮ "версия 1.0". Затем мы продолжили работу над кодом и 
снова стали добавлять в СУ5 новые файлы и изменять файлы, 
существующие в ней. В определенный момент мы снова сказали 
"Стоп" и назвали совокупность файлов в СҮЅ "версия 2.0". 
Основной проблемой, которую мы взрастили, стала мешанина, 
начавшаяся в тот момеит, когда мы не разделили файлы версии 
1.0 и версии 2.0. 


Идем дальше. 


Представьте себе дерево, т.е. 


ствол, и 
ветви, растущие из ствола. 
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Вот как мы должны были поступить с самого начала: 


• файлы, созданные вплоть до момента релиза версии 1.0), 
были основой, т.е. виртуальным стволом (іғипК), нашего ПО; 


Ствол 


• из этого ствола мы могли создать виртуальную ветвь 
(или бранч, от англ. Бгапсй) под названием "версия 1.0", 
которая включала бы все файлы версии 1.0 в редакциях 
(версиях) на момент, когда мы сказали "Стоп " для версии 
1.0. Мы говорим "Стоп" после того, как код написан и 
готов для интеграции и тестирования; 

• таким образом, у нас появились бы ствол и одна ветвь; 


Бранч 1,0 


Ствол БИРИГА 


• программисты, пишущие код для версии 2.0, должны были 
модифицировать код ствола (нарисунке — пунктиром); 


Бранч 1.0 


Ствол И ОА 


• и когда код версии 2.0 был бы дописан, мы создали бы еще 
одну ветвь и назвали ее "версия 2.0"; 

• таким образом, у нас был бы ствол, из которого сначала 
рос бы бранч версии 1.0 и затем бранч версии 2.0; 


Бранч 1.0 Бранч 2.0 


Ствол ПИ 


• начиная работать над кодом релиза версии 3.0, мы снова 
работаем со стволом (на рисунке — пунктиром); 


Бранч 1.0 Бранч 2.0 


Ствол ой 
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Таким образом, код каждой версии живет в СҮ в виде отдель- 
ного бранча или ствола. 


Кстати, есть множество нюансов, например слияние бранча и 
ствола, и ситуации, когда бранч сам становится стволом с вет- 
вями и прочее, но я не буду вас этим загружать. Сейчас мне нуж- 
<:но, чтобы вы поняли главное. 


Теперь вернемся к нашим баранам. Что сделано — то сделано. 
Сейчас в СҮЅ у нас есть 


• весь код версии 1.0; 
• весь код версии 2.0; 
• часть кода версии 3.0. 


Пусть все это содержимое СҮЅ будет нашим стволом. Я берусь 
найти совокупность файлов с редакциями, которые были у нас на мо- 
мент релиза 2.0, и обратным числом создать из них бранч 2.0, что- 
бы в случае фиаско с версией 3.0 мы могли быстро вернуться к коду 
версии 2.0 и вообще начали хорошую традицию создания бранчей». 


Выслушав Митю и мысленно поаплодировав ему, разберемся, 
что даст реализация Митиного предложения: 


Во-первых, мы всегда сможем вернуться к предыдущей версии, 
если новая версия окажется некачественной. 


Во-вторых, программисты 


• смогут работать одновременно над различными версиями, 
например ремонтировать баги для 2.0 (бранч 2.0) и писать 
код для 3.0 (ствол) и 

• результаты их работы над каждой из версий будут в С/5 
отделены друг от друга. 


В этом случае ууу, таїп. іеѕіѕћор.ғѕ будет веб-сайтом с кодом для 
3.0 и вообще площадкой для билдов каждого нового релиза, а, 
скажем, ууу. о4.4ея5йор.т5 будет веб-сайтом с кодом для 2.0 и 
вообще площадкой с кодом каждого предыдущего релиза. 


В-третьих, мы сможем руководить состоянием бранчей. 


У бранча есть три состояния: 


1) открытый, т.е. в нем можно сохранять файлы; 
2) условно открытый, в нем можно сохранять файлы, НО 
при определенном условии, например, программист дол- 
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жен написать номер реального бага в комментарии при со- 
хранении файла; 3) закрытый. В этом случае файл может 
быть сохранен в соответствии с процедурой о неотложном 
ремонте багов (о процедуре через минуту). 


Кстати, когда мы говорили о замораживании спеков, используя СУ$, 
нужно понимать, что бранчи, в которых сохраняются спеки, не имеют 
никакой связи с бранчами, в которых сохраняется код. Как правило, это 
даже две С\У$, установленные на двух разных машинах, но если даже 
используется одна и та же СУ$ на одной и той же машине, то бранчи 
для спеков и бранчи для кода — это как два сына одной женщины 
(т.е. СМ5), один из которых мочит одноклассников в сортирах, а другой 
в это время читает Артура Шопенгауэра. 


Кстати, часто возникает ситуация, когда программист сохранил код в 
бранче для патч-релиза и забыл сохранить исправленный код в стволе, 
т.е. в коде, из которого будет сделан бранч для следующего релиза. 
Таким образом, может получиться ситуация, когда баг, патч для кото- 
рого уже был выпущен на машину для пользователей в предыдущем 
релизе, вновь появляется в следующем релизе. Чтобы избежать таких 
казусов, тестировщики придерживаются железного правила: на каж- 
дый баг, для которого был произведен патч-релиз, должен быть 
написан тест-кейс приоритета 1. Этот тест-кейс добавляется к группе 
тест-кейсов для регрессивного тестирования соответствующей функ- 
циональности. 


Совместим наш цикл разработки ПО с открытостью бранчей. 


1. Во время стадии кодирование, например, для версии 3.0 
бранч с версией 3.0 является открытым. 

2. Во время стадии тестирование и ремонт багов бранч явля- 
ется условно закрытым — никакой код не может сохра- 
няться в таком бранче, за исключением кода с починкой 
для конкретного бага, при сохранении кода в СУ5 програм- 
мист обязан указать номер открытого бага в СТБ, иначе С/5 
не разрешит слескіп. Именно такой статус у бранча после 
заморозки кода и передачи кода тестировщикам. 

3. После того как произошел релиз на машину для пользова- 
телей и в этом релизе найден баг, у нас есть два варианта: 


а) если баг некритический (например, отсутствует проверка 
е-мейла пользователя на два "(@"), то его можно отре 
монтировать в следующем релизе, т.е. мы фиксируем код 
только в стволе; 

б) если баг критический (например, невозможно совершить 
покупку), то нужно отремонтировать его и выпустить патч- 


Цикл разработки ПО 119 


релиз как можно быстрее. Для такого срочного ремонта 
нужен формальный документ: процедура о неотложном 
ремонте багов (Етегоепсу Вис Еїх Ргосейиге). 


Кстати, не хочу вас путать, но есть одна важная для понимания вещь: 
иногда нужно незамедлительно изменить код приложения на машине 
для пользователей, и это изменение не связано с багами. В таком 
случае тоже заносится запись в СТБ, но с типом "Ееаіиге Редиеѕї" — 
запрос о новой функциональности (подробнее об этом в разговоре 
о СТБ), и релиз такого кода регулируется этой же процедурой. 


Примером, в котором нужен быстрый, не связанный с багами 
релиз, может послужить ситуация, когда у нас есть решение суда 
(например, о нарушении патента), которое обязывает срочно из- 
менить код. 


Релиз такого кода также называется патч-релизом. 


Вопрос: В чем отличие такого патч-релиза от дополнительного 
релиза? 

Ответ: В том, что дополнительный релиз — это плановый релиз, 
когда было заранее решено, что такие-то функциональности уви- 
дят свет, но включены они будут не в основной, а в дополнитель- 
ный релиз. 


Процедура о неотложном ремонте багов должна содержать: 


• приоритет багов, которые подлежат НРБ. Например, это 
могут быть только ПІ баги; 

• список лиц, имеющих право инициировать процесс НРБ; 

• последовательность действий между лицами, участвую- 
щими в НРБ, например: 


1) программист, извещенный о проблеме, фиксирует баг; 

2) исправление кода заверяется одним из его коллег через 
рассмотрение кода (сое гелем»); 

3) релиз-инженер делает билд для регрессивного тести- 
рования; 

4) тестировщик производит тестирование; 

5) релиз-инженер делает патч-релиз на машину для поль- 
зователей; 


коммуникацию между лицами, участвующими в НРБ. На 
пример, в начале и конце каждого из этапов ответственное 
лицо отвечает всем на последний е-мейл этой цепочки. 
Причем в начале этапа посылается е-мейл типа "Начал де 
лать билд для регрессивного тестирования. Примерный 
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срок до завершения операции — 30 минут". В конце этапа 
посылается е-мейл типа "Билд для регрессивного тестиро- 
вания завершен. Тестировщики. Ау!". 


Во многих компаниях для быстрого и эффективного исправления 
проблем после основного релиза по примеру полицейских созда- 
ются 5Й’АТ-команды (5реса И’еароп5 апа Тасіісѕ 1еату — под- 
разделения оперативного реагирования), по минимуму состоящие 
из продюсера, программиста, релиз-инженера и тестировщика. 
Допустим, у нас есть четыре такие команды. Для каждой их 
них устанавливается расписание на каждый день (по шесть 
часов каждая) на 10 дней после релиза, так чтобы по звонку в 
любое время дня и ночи головорезы соответствующего под- 
разделения были готовы сорваться, приехать в офис и сидеть до 
посинения, пока патч-релиз не вылетит на машину для поль- 
зователей. 


В начале завершения разговора о релизах поговорим о бета- 
тестировании. 


Иногда интернет-компании производят бета-релиз (читается как 
"бэта") (Бе гееа5е). Идея бета-релиза заключается в следую- 
щем: перед тем как мы сделаем основной "официальный" релиз, 
т.е. откроем новый код всем пользователям, мы откроем новый 
код лишь ограниченной группе пользователей, которые нам его и 
протестируют. Эти пользователи (или "бета-тестировщики" — 
реа іеѕіегѕ) должны являться представителями целевой аудито- 
рии (1агэе! отоир), для удовлетворения потребностей которой и 
был затеян весь сыр-бор от идеи до поддержки. Бета-тестиров- 
щики служат подопытными кроликами, ценность которых заклю- 
чается в том, что они, являясь типичными пользователями, будут 
делать с бета-версией веб-сайта те же вещи, что и остальные 
пользователи после официального релиза, и, следовательно, зара- 
нее столкнутся с непойманными (нами) багами, о которых они и 
сообщат в нашу компанию. Наша интернет-компания отремонти- 
рует эти баги и выпустит официальный релиз, более качествен- 
ный, чем бета. Примером, когда было использовано бета-тести- 
рование (Бе іеѕііпе), может послужить сервис Стаі! компании 
Соое1е (кстати, основанной москвичом Сергеем Брином). 


В некоторых случаях компания не организует бета-тестирова- 
ние с ограниченным числом пользователей, а производит основной 
релиз и помещает картинку или текст со словом "Веіа", что 
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означает "Пользуйтесь на свой страх и риск. Код свежий. Вполне 
возможны баги ". Так как данная ситуация не укладывается в идею 
бета-релиза, то мы назовем такой релиз псевдобета-релизом. 


Истинные и псевдобета-релизы, как правило, имеют место в двух 
случаях: 


1. Первый релиз в жизни интернет-компании, например ре- 
лиз версии 1.0 сайта ууу. ѓеѕіѕйор. г. 

2. Релиз большого и важного подпроекта, являющегося ча- 
стью основного проекта, например сервис Стай, являю- 
щийся частью проекта Соое/е. 


Логичным будет вопрос: "Если есть бета-тестирование, должно 
быть и альфа-тестирование?" Ответ: "Правильно". 
Рассказываю: 


Альфа-тестированием называется любое тестирование кода ДО 
передачи его пользователям (включая бета-пользователей). 
Юнит-тестирование, о котором мы уже говорили, является видом 
альфа-тестирования. Продюсер может попросить у программиста 
покопаться на плэйграунде последнего, когда код уже работает, и 
проверить, как были воплощены в жизнь его (продюсера) мечты 
из спека, и это тоже будет альфа-тестирование. 


Родственное В альфа- И бета-тестировании — ЭТО то, что цель 
каждого из них — поиск багов. 


Чуждое В альфа- И бета-тестировании — ЭТО то, что в подавляю- 
щем большинстве случаев альфа-тестирование исполняется внут- 
ренними ресурсами компании, а бета-тестирование —— внешними. 


В продолжение завершения разговора о релизе 


подчеркнем, что тестировщики интернет-компаний находятся в 
привилегированном положении по сравнению с их коллегами из 
всех других сфер бизнеса. В случае пропуска серьезного бага на 
машину для пользователей этот баг можно устранить в течение 
получаса, иногда даже с минимальной стоимостью и без ведома боль- 
шинства пользователей о том, что баг вообще когда-то существовал. 


А что, если баг обнаружен в подвеске автомобиля? Из-за отзыва 
целого модельного ряда (нормальная деловая практика западных 
автокомпаний) и негативной рекламы бренда убытки будут про- 
сто неизбежны! 
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В завершение завершения разговора о релизе: 


• Релиз проводится в то время, когда большинство пользова- 
телей неактивны. Как правило, это ночь. Время подберете 
сами исходя из того, в каком часовом поясе находится 
большинство ваших пользователей. 

• Во время релиза на уи. ѓеѕіѕйор.тѕ вывешивается таблич- 
ка, что, мол, "Производим техническую поддержку, не от- 
чаивайтесь, примерно в 6.00 по Москве все вернется на 
круги своя. Просим извинить за временные неудобства". 


Пример 

Пользователь, первый раз сделавший покупку на имлу.іеѕіѕһор.гѕ, про- 
снулся в час ночи и хочет проверить статус своего заказа. Он набирает 
в браузере иму.іеѕіѕһор.гѕ и видит "404 їе пої юипа". Конечно, он 
проведет остаток ночи в терзаниях, а потом эмоционально расскажет 
всем своим друзьям (и правильно сделает), какие редиски работают в 
имиууу.іеѕїѕһор.гѕ, что вот полночи не спал из-за того, что мысленно 
прощался с честно заработанными 300 рублей. 


Обратная же ситуация будет, когда опять же в час ночи пользователь 
увидит на имљу.іеѕіѕһор.г5 сообщение, подробно объясняющее обычную 
для оп-!те-бизнеса ситуацию, завершающееся вежливым "Извините". 


В бизнесе любой интернет-компании наступают сезонные вспле- 
ски активности пользователей, например, в США это канун като- 
лического Рождества и Нового года. В такие периоды на все ре- 
лизы, кроме патч-релизов, фиксирующих серьезные баги, должен 
быть введен мораторий. Логика тут проста: любой релиз — это 
риск. И мы не хотим идти на этот риск в то время, как 


• огромное количество пользователей нуждаются в беспере- 
бойной работе нашего веб-сайта и 
• наш бизнес делает наибольшие деньги. 


Как и было обещано, переходим к следующей стадии, а перед 
переходом запомним, что часто наряду со словом "релиз" или 
вместо него употребляется равнозначное ризй — "толчок". 


Большая картина цикла разработки ПО 


Пример 
Допустим, у нас есть 


. мама (продюсер), 
• сын 7лет (программист, тестировщик, релиз-инженер и 
служба поддержки), 


Цикл разработки ПО 129 


• папа (пользователь) и 
• неограниченное количество разнообразных деталей конструктора 
для строительства игрушечного дома. 


Мама говорит сыну: "Давай сделаем папе приятное и построим для него 
одноэтажный дом (идея), который должен выглядеть вот так и вот так 
(дизайн продукта)". 


Сын собирает отдельно 


крышу, 
стены, 
двери и 
окна (кодирование). 


Потом происходит соединение всех частей (интеграция), в результате 
которой крыша оказалась меньше, чем нужно, выпуклости дверей не 
совпадают с выпуклостями стен, а окна не подходят по цвету. Сын 
переделывает компоненты, успешно соединяет и начинает пинать домик 
ногами, бросать вниз с семнадцатого этажа и оставлять на ночь в 
наполненной ванной (тестирование). В результате обнаруживаются 
некоторые недоработки (баги), которые постепенно устраняются 
(фиксирование багов). Когда все нормально, домик передается папе 
(релиз), который иногда просит (е-мейл/звонок в службу поддержки 
пользователей), чтобы некоторые проблемы, такие, как неровности 
крыши, с которой падает кружка с пивом (пострелиз-баги), были 
немедленно исправлены (фиксирование пострелиз-багов). 


Вернемся к нашему ууу. ѓеѕіѕйор.т. 


Давайте рассмотрим большую картину цикла разработки ПО в 
динамике. 


Сначала обобщим знания об игроках, их ролях и стадиях цикла с 
их участием. 


Продюсер Разрабатывает и документирует Дизайн 
дизайн продукта и документация 


Программист Переводит дизайн продукта на язык Кодирование 
программирования 


Ремонтирует баги Тест и ремонт 


Тестировщик Готовится к исполнению Кодирование 
тестирования 


Исполняет тестирование Тест и ремонт 
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1. Итак, начнем с бара, вернее, с идеи версии 1.0, которая в 
этом баре пришла. 


Встреча в баре 


2. После того как идея у. 1.0 была принята за путеводную звезду 
для первого релиза, наступила стадия дизайн и документация 
у. 1.0 этой идеи. Основное действующее лицо — продюсер. 
А вэто время 


• маркетолог тоже не сидит без дела, а генерирует идеи для 
следующего релиза на стадии идея у. 2.0. 


Встреча в баре 


Идея 
у. 2.0 


3. После того как дизайн и документация у. 1.0 завершены, 
наступает стадия кодирование у. 1.0. Основное дейст- 
вующее лицо — программист. 


А вэто время 


• тестировщик планирует, как он будет тестировать код, 
разрабатываемый сейчас программистом; 

• продюсер работает уже над стадией дизайн и документа- 
ция у. 2.0, переданной после стадии идея у. 2.0; 

• маркетолог работает над стадией идея у. 3.0. 


Встреча в баре 


Идея 
у. 2.0 


у 
Дизайн и Идея 
документация 
у. 2.0 у. 3.0 


Кодирование 
у. 1.0 
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4. После того как кодирование у. 1.0 завершено, наступает 
стадия тестирование и ремонт у. 1.0. Основное дейст- 
вующее лицо — тестировщик. После завершения стадии 
тестирование и ремонт у. 1.0 в одну из лунных ночей 
происходит релиз у. 1.0, после чего тестировщик броса- 
ется на У. 2.0, начав подготовку к тестированию кода, раз- 
рабатываемого сейчас программистом на стадии кодиро- 
вание у. 2.0. 


А вэто время 


• программист пишет код на стадии кодирование у. 2.0; 

продюсер разрабатывает дизайн продукта на стадии ди- 
зайн и документация у. 3.0; 

маркетолог, идущий, как всегда, в авангарде, обдумывает 
идеи на стадии идея у. 4.0. 


Дизайн и 
документация 
у. 2.0 


Дизайн и 
документация 


Таким образом, мы рассмотрели полностью цикл разработки 
версии 1.0 проекта илри4ез5йор.т5. Дальше все идет по ана- 
логии. 
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Итак, большая картина цикла разработки ПО. 


Дизайн и 
документация 
у. 2.0 


Тестирование Дизайн и 


и ремонт документация 
у. 2.0 ЕУР у. 4.0 


естирование 
и ремонт 
у. 4.0 


Большая картина — это всего лишь модель, и в реальной 
жизни все так гладко, красиво и гармонично не бывает. На- 
пример, во время стадии идея у. 2.0 маркетолог может генери- 
ровать как краткосрочные идеи цикла у. 2.0, так и долгосрочные 
цикла у. 4.0 иу. 5.0. 


В завершение беседы о цикле разработки ПО давайте * 


поставим акцент на паре важных моментов, 
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• сделаем одну оговорку, 
• остановимся на одной ценной мысли и 
• ответим на практические вопросы. 


Пара важных моментов: 


1. Процедуры, стандарты, спеки, тест-кейсы и контактная 
информация ДОЛЖНЫ быть задокументированы (пусть даже 
в электронном виде) и доступны на интранете. 

2. Такие вещи, как утверждение спека, рассмотрение тест- 
кейсов или инспекция кода, — это не какие-то полицей- 
ские мероприятия, призванные подрезать крылышки твор- 
ческим и свободным личностям. Совершенно наоборот == 
это средства, позволяющие 


• улучшить качество, 
• прикрыть спину, 
• стать хорошим людям еще лучше. 


Оговорка: 


В аквариумах интернет-компаний кроме продюсеров, програм- 
мистов, тестировщиков и начальников обитает еще много других 
разновидностей не менее полезных особей, таких, как 


• веб-дизайнеры; 

• системные администраторы и администраторы баз данных; 
• народ из службы поддержки и маркетинга; 

• бухгалтеры (хлещущие чай); 

• спецы по железу (хлещущие пиво) и др. 


Мы их всех любим, ценим и, как видите, не забываем. Просто 
нужно было сделать допустимое упрощение для удобства вос- 
приятия нового материала и, например, свести написание кода 
только к программистам, в то время как Јауа$сгірі-кол обычно 
пишется веб-дизайнерами. 


Ценная мысль: 


Акт планирования, будь то спек, дизайн кода, тест-кейс или до- 
кумент о неотложном ремонте бага, — это возможность посмот- 
реть в будущее, предугадать и предотвратить возможные про- 
блемы и/или баги. 


Эффективное планирование — это одна из важнейших со- 
ставляющих процесса разработки ПО. 
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Вопросы и задания для самопроверки 


1. 
2. 


21. 


22. 
23. 


24. 


25. 
26. 


27. 
28. 
29. 
30. 


Перечислите стадии цикла разработки ПО. 
Какой баг дороже: пойманный не во время написания спека или 
во время тестирования? 


В Перечислите болезни спеков. 
д Почему продюсер не должен давать в спеке технических инст- 


рукций? 


. Для чего нужно утверждение спека? 

. Для чего нужно замораживание спека? 

. Почему спеки нужно хранить в СМ$? 

. Перечислите и прокомментируйте причины появления багов кода. 
. Что такое юнит-тест? 


Что такое инспекция кода и как она помогает вывести на чистую воду 
подлецов, которые считают, что чем запутаннее код, тем лучше? 


. Для чего нужно замораживание кода? 


Каковы преимущества постоянной интеграции кода? 

Какие баги ловятся компайлером (интерпретатором)? 

Какие баги НЕ ловятся компайлером (интерпретатором)? 
Почему файлы с тест-комплектами нужно хранить в СУ$? 
Почему рассмотрение тест-кейсов выгодно не только компании, 
но и самому тестировщику? 

Что такое тест приемки? 

Что случается, если тест приемки не пройден? 

В чем отличия тестирования новых функциональностей от рег- 
рессивного тестирования? 


. У нас после каждого релиза появляются тест-кейсы, которые мы 


должны исполнять в последующих релизах для регрессивного 
тестирования. Соответственно наступает момент, когда столько 
тест-кейсов для регрессивного тестирования, что нет никакой воз- 
можности их исполнить в пределах временных рамок без ущерба 
для исполнения тест-кейсов для новых функциональностей. Что 
делать? (Ответ будет в одном из следующих разговоров.) 
Придумайте аналогию из жизни, чтобы проиллюстрировать 
слово "релиз". 

Перечислите виды релизов. 

Может ли быть в основном релизе код с зафиксированными 
багами предыдущего релиза? 

Если ответ на предыдущий вопрос положительный, то почему 
мы не выпустили патч-релиз, а ждали следующего релиза? 

Что означает номер релиза 11.44? 

Обоснуйте необходимость СМ$ для процесса разработки ПО и 
релиза. 

Что такое бранч С\$ и для чего он нужен? 

Назовите состояния бранча и условия для этих состояний. 

Что такое процедура о неотложном ремонте багов и зачем она нужна? 
Почему для бета-тестирования набирают народ из типичных 
пользователей? 


ЧАСТЬ 2 


* ЦИКЛТЕСТИРОВАНИЯ ПО 


* КЛАССИФИКАЦИЯ ВИДОВ 
ТЕСТИРОВАНИЯ 


— За что выпьем? 
За красоту? 


— Ты еще за здоровье 
тестировщиков выпей, 
пижон! 


Цикл 
ТЕСТИРОВАНИЯ ПО 


® ИЗУЧЕНИЕ И АНАЛИЗ ПРЕДМЕТА ТЕСТИРОВАНИЯ 
• ПЛАНИРОВАНИЕ ТЕСТИРОВАНИЯ 
® ИСПОЛНЕНИЕ ТЕСТИРОВАНИЯ 


ока мы еще не остыли от цикла разработки, предлагаю не- 
медленно рассмотреть цикл тестирования. 


Поехали. 


Отвлечемся от компьютеров и представим ситуацию, когда 
нужно проверить, ну, например, свежекупленный десятире- 
жимный пылесос. После того как агрегат вытащен из коробки, 
берем "Инструкцию по использованию" и мытарим чудо техники, 
пока все десять режимов не докажут свою лояльность и пре- 
данность. 


Если посмотреть на процесс более абстрактно, можно увидеть 
три вещи, которые явились моделью пылесосного тестирования: 


1. Прочитали, например, пункт 2п инструкции, чтобы понять, 
как работает режим влажной уборки. 
2. Мгновенно в уме составили план проверки влажной уборки: 


а. Налить горячую воду в верхний бачок пылесоса. 
б. Нажать на кнопку Ромег. 

в. Нажать на кнопку Риеззиге. 

г. Итд. ит. 


3. Осуществили проверку согласно плану. 
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Перейдем от тестирования пылесосов к тестированию ПО. 


Цикл тестирования ПО состоит из трех этапов: 


1. Изучение и анализ предмета тестирования. 
2. Планирование тестирования. 
3. Исполнение тестирования. 


На любом из этапов может быть найден баг (как в ПО, так и в 
документации), баг должен быть отремонтирован ответственным 
товарищем (например, программистом или продюсером), и 
качество ремонта должно быть сертифицировано тестиров- 
щиком. 


Свяжем цикл тестирования с циклом разработки: 


1. Изучение и анализ предмета тестирования 


начинаются перед утверждением спека (в завершение стадии 
"Разработка дизайна продукта и создание документации") и про- 
должаются на стадии "Кодирование". 


2. Планирование тестирования 


происходит на стадии "Кодирование". 


3. Исполнение тестирования 


происходит на стадии "Исполнение тестирования и ремонт багов". 


Важный момент: 


показанная связь между циклом разработки ПО и циклом тести- 
рования — это всего лишь типичная модель взаимодействия 
процессов, в то время как на практике, и особенно в стартапах, 
встречается множество ситуаций, когда, например, нет спеков, 
код уже написан и его срочно нужно протестировать навскидку, 
нет времени на создание тест-документации и пр. Поэтому пред- 
лагаю, чтобы мы, изучая цикл тестирования, абстрагирова- 
лись от цикла разработки. 


Что нам это даст? Гибкость, так как, 


зная цикл тестирования как независимый процесс, мы сможем 
легко связать его с любым циклом разработки ПО в любой ин- 
тернет-компании. 
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Итак, независимый процесс, называемый циклом тестирования 
ПО, состоит из трех стадий: 


1. Изучение и анализ предмета тестирования. 
2. Планирование тестирования. 
3. Исполнение тестирования. 


1. Изучение и анализ предмета тестирования 


Вопрос: что можно протестировать в интернет -проекте? 
Легитимные варианты ответа: 


• интерфейс пользователя (например, что определенная кноп- 
ка называется "Купить", а не "Кипуть"); 

• скорость работы веб-сайта (например, то, что при одно- 
временной работе с сайтом 200 пользователей скорость за- 
грузки веб-страницы составляет не более 5 секунд); 

• документацию (например, что спек не содержит противо- 
речий и неточностей). 


Все это правильно, но есть нечто более важное. 


Вопрос: для чего пользователи приходят на наш веб-сайт? Ответ: 
для удовлетворения своих потребностей — покупка книг, чтение 
анекдотов, проверка баланса кредитной карты и т.д. и т.п. 


Вопрос: как можно удовлетворить потребности пользователя? 
Ответ: нужно 
• придумать (продюсер), 
• написать (программист), 
• протестировать (тестировщик) и 
• передать пользователям (релиз-инженер) 


средства, которые эти потребности удовлетворят. Этими средст- 
вами являются ФУНКЦИОНАЛЬНОСТИ интернет-проекта. 


Вот формальное определение: 


функциональность (ииспопашу, јгаіиге) — это средство для 
решения некой задачи. 


Примеры из реальной жизни 


Функциональность компьютерных колонок "Моіите" решает задачу 
"Как изменить аромкость звука". 

Функциональность "Казино" решает задачу "Как незаметно для себя 
потратить все отпускные деньги". 

Функциональность "Принтер" решает задачу "Как распечатать документ". 
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Примеры из виртуальной жизни 


Функциональность "Корзина" решает задачу "Как хранить информацию 
о товаре, выбранном пользователем". 

Функциональность "Добавление товара в корзину" решает задачу "Как 
добавить товар в корзину". 

Функциональность "Удаление товара из корзины" решает задачу "Как 
удалить товар из корзины". 


Проверка работы функциональностей называется функциональ- 
ным тестированием (илсііопа! іеѕііпо). 


Стратегический момент: так как функциональное тестирова- 
ние — это ось, вокруг которой вертится деятельность большин- 
ства тестировщиков, то, следовательно, вокруг нее же будет 
"вертеться " и большинство наших последующих бесед. 


Важность функционального тестирования состоит в том, что 
функциональности — это не что иное, как продукт, предос- 
тавляемый пользователям интернет-компанией, и если про- 
дукт от релиза к релизу кишит багами, то вместе со счастьем 
пользователей убывают и прибыли интернет-компании. 


Основными источниками знания о функциональностях служат: 


• документация... 
в электронном или распечатанном виде — спеки, макеты, 
блок-схемы и прочие руководящие документы, на основа- 
нии которых программист пишет код, а тестировщик пла- 
нирует тестирование. Примером "прочего руководящего 
документа" может служить "Инструкция Мастеркард о 
формате файлов с транзакциями"; 


• хомо сапиенс, т.е. 

информация постигается через межличностное общение. 
Так, в случае возникновения сомнений никогда не мешает 
подойти к продюсеру, хлопнуть его по плечу и попросить: 
"Старина, будь добр, объясни мне по-простому пункт 146 вот 
этого спека". Здоровая дружеская атмосфера в коллек- 
тиве — это отличное средство для предотвращения оши- 
бок в толковании (идеальной питательной среды для багов); 


• сам веб-сайт, 
который мы изучаем посредством эксплоринга. Экепло- 
ринг (ехріогіпе (англ.) — "исследование", "разведка") — 
это изучение того, как работает веб-сайт с точки зрения 
пользователя. 
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Эксплоринг совершается каждым из нас, когда мы приходим на 
некий веб-сайт и истязаем его, заполняя формы, нажимая на 
кнопки, кликая на линки и совершая прочие действия для того, 
чтобы понять, как работает та или иная функциональность. 


В интернет-компаниях эксплоринг, как правило, применяется в 
двух случаях: 


• когда написан код и отсутствует документация. Подоб- 
ная ситуация часто поджидает первого тестировщика, при- 
ходящего в работающую интернет-компанию; 

• для самообучения. Например, в крупных интернет-компа- 
ниях вновь нанятые тестировщики в течение нескольких 
недель проходят тренинг, часть которого посвящена экс- 
плорингу. 


Кстати, при эксплоринге источником ожидаемого результата слу- 
жат наши драгоценные жизненный опыт, опыт работы и другие 
ранее перечисленные помощники, не относящиеся к спекам. 


Кстати, хорошая идея для тестировщика, помогающая лучше понять 
функциональности своего проекта, — это стать обычным пользовате- 
лем своего и аналогичных веб-сайтов. Выражение "Еаі уоиг оип од 
Тооа" ("Ешь еду своей собаки") для тестировщика означает "Если ты 
тестируешь веб-сайт, продающий книги, то ты должен сам покупать 
книги по Интернету". 


Идем дальше. 


Конечной целью этапа Изучение и анализ предмета тестирова- 
ния является получение ответов на два вопроса: 


а. Какие функциональности предстоит протестировать? 
б. Как эти функциональности работают? 


После того как ответы получены, мы переходим к следующему 
этапу цикла. 


2. Планирование тестирования 


Эта стадия требует от тестировщика наибольшего творчества и 
профессионализма, так как именно на ней решается множество 
головоломок, отвечающих на один простой вопрос: "Как будем 
тестировать?", причем качество продукта (а значит, и счастье поль- 
зователей) напрямую зависит от, не побоюсь сказать, мудрости 
найденных решений. 
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Мудрость найденных решений проявляется в двух вещах: 


а) кратких, простых и изящных путях для проверки 
функциональностей; 


6) компромиссе между 

объемом тестирования, который возможен в теории; 
объемом тестирования, который возможен на практике. 
Ответы на "один простой вопрос" предстают перед 
миром в виде тест-документации (ЕезЕ аоситепеаЕ1оп), 
ядро которой составляют наши любимые тест-кейсы. Во 
многих случаях создание тест-документации 
сопровождается написанием тестировщиком вспо- 
могательных тулов (Е001 — компьютерная программа), 
которые облегчают исполнение тестирования. 


Идем дальше. 


3. Исполнение тестирования 
Суть исполнения тестирования — это практический 
поиск багов в написанном коде с использованием 
тест-кейсов, созданных ранее. 


Исполнение функционального тестирования выглядит 
следующим образом: 

сначала идет проверка новых функциональностей по 
новым тест-кейсам. Кстати, давайте вспомним, что во 
многих случаях новы тест-кейсы редактируются, 
проходя обкатку первым исполнением; 


затем проверка старых функциональностей по старым 
тест-кейсам. 


То же самое, но в профессиональной терминологии: 


тестирование новых функциональностей (пем Ееабиге 
ЕезЕ1п9) и соответственно 


регрессивное тестирование (гедгеѕѕіоп Ёеѕііпд). 

Мы исполняем тест-кейсы, рассчитывая найти баги. 
Давайте еще раз вспомним, что 

после нахождения бага тестировщик заносит запись о 
нем в систему трэкинга багов; 


после того, как программист починил баг, 
тестировшик проверяет: 
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а) действительно ли баг был починен. Проверка 
осущест 

вляется путем исполнения шагов, которые ран прив 
ли к багу, или, в профессиональной терминологии, пу 


тем генерации ввода, который привел к выводу, не со 
ответствующему ожидаемому результату; 


6) не появились ли новые баги как нечаянное 
следствие 
изменения кода при починке. Проверка осуществляется 


путем тестирования функциональностей, работа кото 
рых могла быть затронута починкой. 


Тестирование, исполняемое в пунктах а) и 6), также 
называется регрессивным тестированием (рид гедгеѕѕіоп 
ЕезЕ1па). Соответственно выражение "гедгезз һа рид" 
(проведи регрессивное тестирование этого бага) 
означает, что нужно последовательно исполнить пункты а) 
и 6). 


Идем дальше. 


Давайте сделаем небольшое обобщение. 


Так как этапы 1. Изучение и анализ предмета 
тестирования и 


2. Планирование тестирования переплетены между собой, мы 
объединим их в контейнер знания, который называется 
подготовка к тестированию (Ғеѕі ргерагаѓёіоп или, по- 
ростому, Ёеѕё ргерѕ). 


Итак, большая часть нашего дальнейшего общения будет 
освящена двум вещам: 


Подготовка к тестированию (ЕезЁргерагаЕ Топ); 
Исполнение тестирования (ЁезЕЁЕ ехесиѓіоп). 
Краткое подведение итогов 

Функциональность — это средство для решения некой задачи. 


Проверка работы функциональностей называется функциональным 
тестированием. 


Эксплоринг — это изучение того, как работает веб-сайт с точки зрения 
пользователя. 


Ядро тест-документации составляют наши любимые тест-кейсы. 


Вспомогательные программы ("тулы") пишутся для облегчения исполнения 
тест-кейсов. 


Мы выделили два основных этапа цикла: 


подготовка к тестированию; 
исполнение тестирования. 


138 


7. 
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Исполнение тестирования идет в два этапа: 


• тестирование новых функциональностей и 
• регрессивное тестирование. 


Вопросы для самопроверки 


1. 


2. 


Почему полезно представлять себе цикл тестирования ПО неза- 
висимым от цикла разработки ПО? 

Назовите источники информации о функциональностях. 

Что такое эксплоринг и как он помогает в состоянии документа- 
ционного вакуума? 

Назовите два основных элемента стадии подготовка к тестиро- 
ванию. 

Что такое регрессивное тестирование? Назовите две ситуации, 
при которых проводится регрессивное тестирование. 

Почему сначала тестируются новые функциональности? 


КЛАССИФИКАЦИЯ ВИДОВ 
ТЕСТИРОВАНИЯ 


• ПОЗНАНИЮ ВНУТРЕННОСТЕЙ СИСТЕМЫ 

® ПО ОБЪЕКТУ ТЕСТИРОВАНИЯ 

® ПО СУБЪЕКТУ ТЕСТИРОВАНИЯ 

® ПО ВРЕМЕНИ ПРОВЕДЕНИЯ ТЕСТИРОВАНИЯ 

® ПО КРИТЕРИЮ "ПОЗИТИВНОСТИ" СЦЕНАРИЕВ 

® ПО СТЕПЕНИ ИЗОЛИРОВАННОСТИ ТЕСТИРУЕМЫХ 
КОМПОНЕНТОВ 

® ПО СТЕПЕНИ АВТОМАТИЗИРОВАННОСТИ ТЕСТИРОВАНИЯ 

® ПО СТЕПЕНИ ПОДГОТОВКИ К ТЕСТИРОВАНИЮ 


юбая классификация составляется по определенному при- 
знаку, например: 


• по полу люди делятся (классифицируются) на мужчин и 
женщин; 

• по наличию кошки люди делятся на тех, у кого кошка 
есть, и тех, у кого ее нет; 

• по росту люди делятся на группы в зависимости от коли- 
чества сантиметров от земли до макушки (например, один 
будет в группе "181 см", а другой — в группе "185 см"). 


Один и тот же субъект может быть одновременно элементом бес- 
численного количества классификаций, при этом прекрасно себя 
чувствовать и не испытывать никаких угрызений совести. На- 
пример, дебошир и романтик Сева Б. может одновременно 


• быть мужчиной, 
• иметь кошку и 
• вырасти до 175 см. 
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— Как много 
девушек хороших. 
Как много ласковых 
имен... 
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Немедленная польза от классификаций в отношении видов тести- 
рования заключается в том, что упорядоченная и обобщенная 
информация легче воспринимается, усваивается и запоминается. 


Замечу, что видов тестирования существует огромное количе- 
ство и мы не будем пытаться объять необъятное, а поговорим 
об основных видах, которых, впрочем, и так хватит с лихвой для 
любого интернет-проекта. 


Сначала перечислим, потом объясним. Объяснения призваны 
дать общее понимание каждого из элементов, в то время как по- 
следующие разговоры это понимание расширят и углубят. 


Формат изложения: 


Классификация по этому признаку 
состоит из следующих элементов. 


Перечисляем: 


1. По знанию внутренностей системы: 


• черный ящик (Ыаск Бох ѓіеѕііпе); 
• серый ящик (эгеу Бох іеѕійпе); 
• белый ящик (уиліе рох іеѕійпе). 


2. По объекту тестирования: 


• функциональное тестирование ({ииспопа/ іеѕіїпе); 

• тестирование интерфейса пользователя (0 1езйиз); 

• тестирование локализации (/осайїгайоп іеѕіпе); 

• тестирование скорости и надежности (/оаа/ѕігеѕѕ/регјог- 
тапсе іеѕііпе); 

• тестирование безопасности (5есигИу іеѕііпо); 

• тестирование опыта пользователя (изабИиу іеѕіпе); 

• тестирование совместимости (сотрайБИйу іеѕііпо). 


3. По субъекту тестирования: 


• альфа-тестировщик (а/рйа іеѕіег); 
• бета-тестировщик (Реѓа 1еяет). 


4 По времени проведения тестирования: 


• до передачи пользователю — альфа-тестирование (а/рћа- 
іеѕіпе); 
- тест приемки (ѕтоќе іеѕі, запиу іеѕі или сопй4епсе іеѕі); 
- тестирование новых функциональностей (леу јгаѓиғе 
іеѕіпе); 
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- регрессивное тестирование (гезтеузтоп іеѕіїпе); 
- тест сдачи (ассеріапсе ог сегийсаноп іеѕі); 


• после передачи пользователю — бета-тестирование (Беа 
1е5 пе). 
5. По критерию "позитивности" сценариев: 
• позитивное тестирование (ро5ЙТуе іеѕііпо); 
• негативное тестирование (пезайуе іеѕііпо). 
6. По степени изолированности тестируемых компонентов: 


• компонентное тестирование (сотропепі іеѕііпе); 

• интеграционное тестирование (їпѓеоғаќоп іеѕійпе); 

• системное (или энд-ту-энд) тестирование (ѕуѕѓет ог епа- 
і0-епа 1е5 ив). 


7. По степени автоматизированности тестирования: 


• ручное тестирование (тапиа! іеѕііпе); 

• автоматизированное тестирование (аиотееа іеѕііпе); 

• смешанное/полуавтоматизированное тестирование (ѕеті 
аиіотаѓеа іеѕііпе). 


8. По степени подготовки к тестированию: 
• тестирование по документации (ўоута//Лоситетіей іеѕіїпо); 
• эд хок-тестирование (а4 йос 1е5 пе). 


Объясняем: 


1. По знанию внутренностей системы 


• черноящичное тестирование (Р/асќ Бох іеѕіїпе); 
• белоящичное тестирование (улііе рох ѓеѕііпе); 
• сероящичное тестирование (оғеу Бох іеѕііпе). 


Кстати, в отношении четких дефиниций, водоразделов и прочих 
академических штучек до сих пор идут споры. 


ЧЕРНЫЙ ЯЩИК (Бас Бох) 


Должен признаться, что лучшие мгновения моего студенчества 
прошли не в аудиториях моей альма-матер, не в залах библиотек, 
а в пивной Коптевского рынка, куда мы с Балмашновым, Гнезди- 
ловым, Дебдой, Ермохиным, Илюхиным, Карповым, Назаровым, 
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Осмоловским, Сапачевым и Тарасовым вламывались с тубусами 
наперевес и за вечер выполняли недельный план по продажам. 


Основным элементом Коптевской пивной того времени была так 
называемая автопоилка, т.е. аппарат, принимающий жетон и вы- 
дающий пол-литра того, что мы тогда считали пивом. 


Так вот если перевести манипуляции с автопоилкой на компью- 
терный ЯЗЫК, ТО 


• жетон был вводом, 

• пиво — выводом, 

• щель для жетона и носик для пива — интерфейсом поль- 
зователя, а 

• механизм автопоилки, обменивающий жетон на пиво, — 
черным ящиком, так как мы не знали (и для сохранения 
аппетита не хотели знать), как был устроен изнутри тот 
столь необходимый для студента аппарат. 


В отношении ПО черный ящик, т.е. область незнания, — это не 
что иное, как тестируемые части бэк-энда (например, код про- 
граммиста, схема базы данных), составляющие невидимый поль- 
зователю виртуальный мост, который соединяет 


фактический ввод (шаги) и 
фактический вывод (фактический результат). 


Признаки подхода "Черный ящик": 


1. Тестировщик не знает, как устроен виртуальный мост. 

2. ИДЕИ для тестирования идут от предполагаемых паттер- 
нов (райеги — образец) поведения пользователей. Поэтому 
подход "Черный ящик" также называют поведенческим. 


Разберем первый признак. 


1. ТЕСТИРОВЩИК НЕ ЗНАЕТ, КАК УСТРОЕН 
ВИРТУАЛЬНЫЙ МОСТ 


С одной стороны, 


тестировщик имеет преимущество перед программистом, т.е. авто- 
ром кода. Давайте будем честны перед собой: мы часто прини- 
маем желаемое за действительное. Особенно это касается того, 
что мы создали сами, например воображаемого образа любимого 
человека. Сколько раз каждый из нас заводил романы с абсолют- 
но неправильными, несовместимыми и нередко вредными для нас 
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людьми и утешал себя, что Й5 о'к — притрется, пригладится и 
поймется. Как показывает жизнь, притирки, пригладки и понима- 
ния ни к чему хорошему не приводят, как и попытки заставить 
программиста произвести функциональное тестирование. 


Вот перевод постинга на одном из форумов по тестированию: 


"Программист не должен проводить тестирование, и давать 
релизу зеленый свет. Нужно, чтобы кто-то независимый (чело- 
век/отдел) был ответствен за поиск багов и уполномочен "дос- 
тавать " программиста до тех пор, пока баг не будет починен. 
Дело в том, что я как программист знаю свой код, и если я сам 
провожу тестирование, то обязательно буду делать допущения, 
что какие-либо части кода работают по умолчанию и их можно 
не проверять. С другой стороны, мои тесты основаны на моем 
понимании того, как работает код, и не учитывают реальных и 
порой абсолютно нелогичных вещей, которые будут делаться поль- 
зователями с моим кодом. С третьей стороны, у меня на тес- 
тирование нет времени, и я не понимаю, почему должен проводить 
тестирование, если за него платят тестировщикам ". 


Реальность — это мир, пропущенный через призму субъективно- 
го восприятия. Например, каждый родитель свято верит, что его 
ребенок самый умный, талантливый и перспективный. Код — это 
дитя программиста, и в своей реальности программист нередко 
воспринимает код как априорно непогрешимый. 


Вот вам легенда про призму восприятия: 


Когда на пути в Индию корабли Колумба остановились перед од- 
ним из Карибских островов, индейцы... этих кораблей не увидели, 
потому что их призмы восприятия не пропускали образы, абсо- 
лютно чуждые тем предметам и явлениям, с которыми они и их 
предки существовали бок о бок на протяжении тысячелетий. И 
лишь шаман, учуяв что-то неладное, несколько дней пристально 
всматривался в горизонт, пока наконец не отделил романтические 
силуэты испанских фрегатов от привычных океана и неба и не ска- 
зал своей пастве: "Опа! Корабли Колумба " (тут, конечно, все сразу 
настроили свои призмы, увидели не замеченные раньше корабли, 
деловито погрузили в лодки свиней и поехали менять их на бусы). 


Идея, думаю, понятна. Программист пишет, тестировщик тести- 
рует, Филипп Филиппыч оперирует, Айседора Дункан танцует, и 
никаких разрух. 
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Итак, блэк бокс-тестировщику, знающему лишь то, для чего был 
написан код (т.е. функциональности), а не как он был написан, легче 
смотреть на тестирование с точки зрения пользователя, для удов- 
летворения чаяний которого весь софтверный сыр-бор и начался. 


С другой стороны, 


блэк бокс-тестирование ведется вслепую, так как ни одна из час- 
тей виртуального моста неизвестна. Следствием этого может 
стать ситуация, когда для вещи, проверяемой одним тест-кейсом, 
пишется несколько тест-кейсов. 


Итак, в случае с черным ящиком тестировщик не знает, как 
устроен виртуальный мост, и это может быть как полезно, таки 
вредно для дела. 


Разберем второй признак. 


2. ИДЕИ ДЛЯ ТЕСТИРОВАНИЯ ИДУТ ОТ ПРЕДПОЛАГАЕМЫХ 
ПАТТЕРНОВ (райеги — образец) ПОВЕДЕНИЯ ПОЛЬЗОВАТЕЛЕЙ 


То, что мы называли вводом (шагами), на самом деле является 
двумя вещами, которые так же неотрывно связаны, как судьбы 
Ромео и Джульетты. Речь идет о 

сценариях и 

данных для сценариев. 


Исполнение тестирования может проходить как при наличии, так 
и без тест-кейсов. Так вот в обоих случаях сценарий (ѕсепагіо) — 
это последовательность ДЕЙСТВИЙ для достижения фактиче- 
ского результата. 


Пример сценария 


1. Открой илуу. таійп.іеѕіѕһор.г. 
2. Кликни линк "сопіасі иѕ". 


Если исполнение тестирования идет по тест-кейсам, то можно ска- 
зать, что сценарий тест-кейса — это совокупность шагов тест-кейса. 


Данные для сценариев, или просто "данные", — это конкрет- 
ные ЗНАЧЕНИЯ ВВОДА, используемые для достижения факти- 
ческого результата. 


Пример данных 


1. Открой ими. таіп.іеѕіѕһор.гѕ. 
2. Введи текст "Затоваренная бочкотара" в поле поиска. 
З. Нажми кнопку "Искать". 


146 Тестирование Дот Ком. Часть 2 


В последнем примере шаги 1 —3 (включительно) были сценарием, 
а "Затоваренная бочкотара" — данными. 


Еще один пример данных 


При закрытии счета в одном из интернет-магазинов на последней 
страниие пользователь должен ответить, почему он закрывает счет. 
Ему дается список из 20 вопросов, и напротив каждого вопроса раз- 
мещен квадрат, куда можно поставить галочку (сһескбох). Так вот если 
пользователь поставит галочку напротив строк "Служба поддержки" и 
"Медленная доставка" и нажмет на кнопку "Закрыть счет", то данными 
будет текст "Служба поддержки "и "Медленная доставка". 


Совместим знания о сценариях и данных со вторым признаком 
подхода "Черный ящик". 


Предполагаемые паттерны поведения пользователей — это те 
сценарии и данные, которые, как мы ожидаем, будут реализо- 
вываться и вводиться пользователями. 


Основные источники предполагаемых паттернов поведения поль- 
зователей могут быть: 


а) напрямую взяты из спека. 


Пример 

Пункт 12 спека #9548 говорит: "Если на странице с регистрационной 
формой пользователь не указал свой е-мейл, то после нажатия на 
кнопку "Зарегистрироваться" показывается та же страница, но с сооб- 
щением об ошибке: "Пожалуйста, введите ваш е-мейл" и с изменением 
шрифта имени текстового поля "Е-мейл." на красный цвет". 


Напишем тест-кейс. 
ИДЕЯ: "Сообщение об ошибке, если при регистрации не указан е-мейл". 
Сценарий: 


1. Открой муму. таіп.іеѕіѕһор.гѕ/гедіѕіег.һіт. 
2. Заполни все текстовые поля кроме "Е-мейл:" действительными 


данными (поле "Е-мейл:"должно быть пустым). 
З. Нажми на кнопку "Зарегистрироваться". 


Ожидаемый результат 1: 
Страница регистрации. 
Ожидаемый результат 2: 
Сообщение об ошибке "Пожалуйста, введите ваш е-мейл". 


Ожидаемый результат 3: 
Шрифт имени поля "Е-мейл." изменен на красный цвет. 


Кстати, данными для сценария из последнего примера послужили две 
вещи: 1) действительный ввод всех полей, кроме е-мейла (мы предпола- 
гаем, что лицо, исполняющее тестт-кейс, знает легитимные значения ввода), 
и 2) пустое поле для е-мейла. Значение ввода ""— это тоже вид данных. 
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Давайте для простоты в дальнейшем использовать термин "сце- 
нарий" в качестве собирательного образа, т.е. самого сценария 
и данных, используемых в нем; 


6) найдены путем эксплоринга. 


Иногда "брожение" по сайту является лучшим источником для 
понимания того, как реальный пользователь будет с ним обра- 
щаться; 


в) получены путем применения методики черноящичного 
тестирования (Р/аск Бох ѓіеѕіїпе теіһоаоіоеу). 


Примеры: впереди будет много примеров; 
г) подарены интуицией. 


Помните, как у Конан Дойля было сказано об инспекторе Лест- 
рейде? Примерно так: "Но была единственная вещь, которая ме- 
шала ему стать настоящим сыщиком, — у него не было чутья". 


А чем мы не сыщики? Интуиция не менее важна для настоя- 
щего профессионала-тестировщика, чем прикладные знания 
и опыт работы; 


д) присоветованы программистом или продюсером. 


Общение, общение и еще раз общение. Самое дорогое — это ин- 
формация, и общение — один из главных ее источников. Продю- 
сер, программист и тестировщик дают путевку в жизнь одной и 
той же функциональности, но каждый смотрит на нее со своей 
колокольни, и если нам, тестировщикам, получить мнения това- 
рищей с двух других колоколен, то можно узнать потрясающе 
полезные вещи; 


е) др. 


Например, мы прочитали статью в Интернет е, давшую классную 
идею для сценария. 


Итак, мы разобрались со вторым признаком подхода "Черный ящик". 
Обобщаем. 


При подходе "Черный ящик" тестировщик не основывает 
идеи для тестирования на знании об устройстве и логике тес- 
тируемой части бэк-энда. Идеи формируются путем предпо- 
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ложений о сценариях, которые будут реализовываться и при- 
меняться пользователями. Такие сценарии называются пат- 
тернами поведения пользователей. 


БЕЛЫЙ ЯЩИК (иййе Бох) 


также известен под именами Стеклянный ящик (о/аѕѕ/сіеағ Бох), 
Открытый ящик (ореп Бох) и даже Никакой ящик (по Бох). 


В отличие от "Черного ящика" при подходе "Белый ящик" тес- 
тировщик основывает идеи для тестирования на знании 0б 
устройстве и логике тестируемой части бэк-энда. 


Таким образом, при белоящичном тестировании сценарии созда- 
ЮТСЯ с МЫСЛЬЮ О ТОМ, чтобы протестировать определенную часть 
бэк-энда, а не определенный паттерн поведения пользователя. 


Пример из жизни 

Допустим, нужно протестировать проходимость нового российского 
внедорожника. 

При подходе "Черный ящик" тестировщик садится за руль, выезжает за 
кольцевую — в объятия подмосковной осени, находит непролазную ка- 
наву, заезжает в нее и пытается выбраться, т.е. он проделывает вещи, 
которые с большой вероятностью будут проделаны основными пользо- 
вателями таких машин — охотниками, рыболовами и рэкетирами. 


При подходе "Белый ящик" тестировщик открывает капот и видит, что 
установлена система полного привода фирмы "Джапан моторз", мо- 
дель КТ6511. Тестировщик знает, что проходимость внедорожника 
зависит именно от ВТ6511 и ее слабое место — это эффективность 
при езде по снегу. Что делает тестировщик? Правильно! Выезжает 
на белую сверкающую гладь русского поля и насилует джип в свое удо- 
вольствие. 


Последний пример не только служит иллюстрацией разницы в 
подходах, но и показывает, что использование методик обоих 
подходов количественно и качественно увеличивает покрытие 
возможных сценариев. 


Идем дальше. 


Постановка мозгов 


Покрытие возможных сценариев — это одна из частей архиважнейшей 
концепции, называемой тестировочное покрытие. 
Забудем на минуту о ПО вообще и о тестировании в частности. 


Представим себе шахматную доску, состоящую из 64 клеток. Единст- 
венная фигура, присутствующая на доске, — белый король. Допустим, 
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каждая возможная позиция короля записана на отдельной карточке: 
"Поставь белого короля на такую-то клетку". Следовательно, у нас есть 
64 карточки, или 100% теоретически возможных вариантов располо- 
жения короля. Если мы будем перемещать короля в соответствии с по- 
зициями на карточках, то, последовательно перелистав все карточки, 
добьемся 100%-й практической реализации предписаний, указанных 
на карточках. 


Теперь усложним задачу и представим, что у нас есть шахматная доска, 
количество клеток на которой так велико, что не поддается подсчету. 
Допустим, что, согласно лишь нам известной логике, в голову нам уда- 
рило выбрать лишь 20 позиций, которые мы опять же зафиксировали 
на карточках. Теперь вопрос: покрывают ли 20 карточек 100% теорети- 
чески возможных вариантов расположения короля? Нет. Можем ли мы 
на 100%о практически реализовать предписания, указанные на 20 кар- 
точках? Да. 


Обратно к тестированию ПО. 


Тестировочное покрытие (їеѕі соуегаде) состоит из двух вещей: 


а. Покрытие возможных сценариев. 
6. Покрытие исполнения тест-кейсов. 


Покрытие возможных сценариев — это в большинстве случаев абст- 
рактная величина, так как в большинстве же случаев невозможно даже 
подсчитать, сколько понадобится тест-кейсов, чтобы обеспечить 
100%-ю проверку ПО (например, попробуйте подсчитать количество 
всех теоретически возможных тест-кейсов для тестирования Майкро- 
софт Ворда-2003). 

Другими словами, в большинстве случаев покрытие возможных сце- 
нариев нельзя представить как процентное отношение сценариев, за- 
фиксированных в тест-кейсах, ко всем теоретически возможным сце- 
нариям. 


Покрытие возможных сценариев может увеличиться либо уменьшиться 
путем прибавления либо отнятия уникального тест-кейса, т.е. тест- 
кейса, 

• который тестирует реальный сценарий использования ПО и 

• который не является дубликатом другого тест-кейса. 
Покрытие исполнения тест-кейсов — это всегда величина кон- 
кретная, и выражается она процентным отношением исполненных тест- 
кейсов к общему количеству тест-кейсов. Допустим, тест-комплект для 
тестирования функциональностей спека #1243 "Новые функциональ- 
ности корзины" состоит из 14 тест-кейсов, и если 7 из них исполнены, 
то покрытие исполнения тест-кейсов равно 50%>. 


Возвращаемся к нашим ящикам. 
Симбиоз использования подходов "Черный ящик" и "Белый ящик" 
увеличивает покрытие возможных сценариев 


• количественно, потому что появляется большее количест- 
во тест-кейсов; 
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• качественно, потому что ПО тестируется принципиаль 
но разными подходами: с точки зрения пользователя 
("Черный ящик") и с точки зрения внутренностей бэк-энда 
("Белый ящик"). 


В реальной жизни белоящичное тестирование проводится либо 
самими программистами, написавшими код, либо их коллегами с 
программистской квалификацией того же уровня. Кстати, юнит- 
тестирование, о котором мы говорили, — это часть иййе рох-тес- 
тирования. 


СЕРЫЙ ЯЩИК (эгау/огеу Бох) 


Это подход, сочетающий элементы двух предыдущих подходов, это 


• с одной стороны, тестирование, ориентированное на поль- 
зователя, а значит, мы используем паттерны поведения поль- 
зователя, т.е. применяем методику "Черного ящика"; 

• сдругой — информированное тестирование, т.е. мы знаем, 
как устроена хотя бы часть тестируемого бэк-энда, и активно 
используем это знание. 


Ярчайший пример 

Допустим, мы тестируем функциональность "регистрация": 
• заполняем все поля (имя, адрес, е-мейл и т.д.) и 
• нажимаем кнопку "Зарегистрироваться". 


Следующая страница — подтверждение, мол, дорогой Иван Иваныч, 
поздравляем, вы зарегистрированы. 


Теперь вопрос: если мы видим страницу с подтверждением регистра- 
ции, то значит ли это, что регистрация была успешной? Ответ: нет, 
так как процесс регистрации с точки зрения нашей системы включает 
не только подтверждение на веб-странице, но и создание записи в 
базе данных, 
т.е. вывод, который стоит проверить, состоит из 

• страницы с подтверждением и 

• новой записи в базе данных. 
Откуда мы почерпнем знание о логике создания записей в базе данных 
при регистрации? Например, из технической документации (документ 
о дизайне/архитектуре системы, документ о дизайне кода), общения с 
программистом, самого кода. 


Как видно из последнего примера, подход "Серый ящик" — это 
дело хорошее, жизненное и эффективное. Деятельность боль- 
шинства профессиональных тестировщиков интернет-проектов 
протекает именно в разрезе сероящичного тестирования. 
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Пара мыслей вдогонку. 


1. Когда мы говорим о поведенческом тестировании, то это не 
значит, что тестировщик ограничен набором действий, совер- 
шаемых пользователем. Во многих случаях специально написан- 
НЫЙ код используется для облегчения тестирования или для того, 
чтобы вообще сделать его возможным. 


Пример 


При разговоре о формальной стороне тест-кейса мы проверяли баланс 
кредитной карты до и после покупки на странице имму. таіп.іеѕіѕћор.г= 
/<четыре последних цифры карты>/ба!апсе.һіт. В реальности поль- 
зователь проверяет баланс кредитной карты на сайте кредитной 
организации, выдавшей эту карту (например, илиим.ме!зТагдо.сот), 
а страница баіапсе.Һіт является специальным кодом, написан- 
ным для тестирования с использованием несуществующих кредит- 
ных карт. 


Кстати, тот факт, что тестировщик использует информацию веб-стра- 
ницы баіапсе.һіт, не означает, что он понимает логику работы кода, 
отвечающего за списание денег со счета. 


2. Как мы видели на примере с регистрацией, выводом, который 
нужно было проверить для реального тестирования, послужила 
не только страница с подтверждением, но и запись в базе данных. 
Так как ожидаемый вывод — это ожидаемый результат на- 
ших тест-кейсов, то огромное значение для эффективности 
тестирования имеет поиск именно того ожидаемого результа- 
та, который реально подтвердит, что код работает. Так, если 
бы в том же самом примере ожидаемым результатом была только 
страница с подтверждением, то проверка базы данных была бы 
лишь тратой времени. 


2. По объекту тестирования 


Функциональное тестирование (ўипсіїопа! іеѕійпе); 

• Тестирование интерфейса пользователя (07 1езйиз); 

• Тестирование локализации (1осай2айоп іеѕйпе); 

• Тестирование скорости и надежности (/оаа/5іғеѕ5/ рег- 
Јоғтапсе іеѕііпе); 

• Тестирование безопасности (5есигИу ѓіеѕііпе); 

• Тестирование опыта пользователя (иѕађі/їу іеѕііпо); 

• Тестирование совместимости (сотрайБИИу іеѕііпе). 
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ФУНКЦИОНАЛЬНОЕ ТЕСТИРОВАНИЕ (йииспопаейис) 


Уже говорили и еще будем много говорить. 


ТЕСТИРОВАНИЕ ИНТЕРФЕЙСА ПОЛЬЗОВАТЕЛЯ 
(ОЛ (читается как "ю-ай") ѓеѕѓіпе) 


Это тестирование, при котором проверяются элементы интерфей- 
са пользователя. Мы рассмотрим все основные элементы веб- 
интерфейса при разговоре о системе трэкинга багов. 


Важно понимать разницу между 


тестированием интерфейса пользователя и 
тестированием с помощью интерфейса пользователя. 


Пример первого 


Проверяем максимальное количество символов, которые можно напе- 
чатать в поле "Имя" на странице "Регистрация", т.е. проверяем, отве- 
чает ли конкретный элемент интерфейса, называющийся "одностроч- 
ное текстовое поле" (їехірох), требованию спецификации, которая ука- 
зывает на максимальное количество символов, которое в этом поле 
можно напечатать. 


Пример второго 


Тестируем бэк-энд и с помощью интерфейса создаем транзакцию по- 
купки, т.е. мы использовали интерфейс пользователя как инструмент 
для создания транзакиии. 


ТЕСТИРОВАНИЕ ЛОКАЛИЗАЦИИ 
([осай2апоп іеѕііпе) 


Многогранная вещь, подразумевающая проверку множества ас- 
пектов, связанных с адаптацией сайта для пользователей из 
других стран. Например, тестирование локализации для поль- 
зователей из Японии может заключаться в проверке того, не вы- 
даст ли система ошибку, если этот пользователь на сайте зна- 
комств введет рассказ о себе символами Каилй, а не английским 
шрифтом. 


ТЕСТИРОВАНИЕ СКОРОСТИ И НАДЕЖНОСТИ 
(Іоаа/5ігеѕѕ/регјоттапсе іеѕіїпе) 


Это проверка поведения веб-сайта (или его отдельных частей) 
при одновременном наплыве множества пользователей. 
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У каждого, кто пользуется Интернетом, есть опыт ожидания, 
когда, например, кликаешь на линк и следующая страница 
медленно высасывает из тебя душу, загружаясь ну оче-е-е-е-нь 
долго. 


Плохой перформанс (скорость работы) — это основная беда 
российских интернет-проектов. 


Менеджмент, который экономит на подобном тестировании, в 
итоге, как правило, глубоко сожалеет об этом, так как современ- 
ный интернет-пользователь — это существо ранимое и нервное, 
если сайт работает медленно, с перебоями или не работает со- 
всем, так как не справляется с наплывом посетителей, то совре- 
менный интернет-пользователь идет куда? Правильно, на сайт 
конкурента, тем более что физически никуда идти или ехать не 
надо, а надо лишь набрать "даблюдаблюдаблю точка адрес кон- 
курента точка ком ". 


Тестирование скорости и надежности — это отдельная техниче- 
ская дисциплина, за хорошее знание которой получают очень 
большие деньги в иностранной валюте. 


Как правило, целью такого тестирования является обнаружение 
слабого места (БоШепес®) в системе. Под системой подразумева- 
ются все компоненты веб-сайта, включая код, базу данных, "же- 
лезо" и т.д. 


В моей практике был случай, когда из-за того, что один из за- 
просов к базе данных был составлен громоздко (с точки зрения 
обработки этого запроса системой), одна интернет-компания 
потеряла много пользователей, так как в течение нескольких 
дней сайт то работал, то не работал, и никто не мог понять, 
ура! Ше һеск 15 соіпе оп ("что за фигня "), пока один из програм- 
мистов не встрепенулся и не исправил код. Прошу заметить, 
что функционально старый код работал прекрасно, но с точки 


зрения перформанса он никуда не годился. 


Скорость и надежность веб-сайта профессионально проверяется 
специальным ПО, которое легко может стоить под 100 тыс. долл. 
(например, 5Ик Регјогтег от $есие или Гоаа Киппег от Мегсигу 
Іпіеғасіуе). 


Упомянутое ПО служит: 


с одной стороны, для генерации наплыва пользователей, 
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с другой — для измерения скорости, с какой веб-сайт в сред- 
нем отвечает каждому из "наплывших" и с третьей — для 
последующего анализа полученных данных. 


ТЕСТИРОВАНИЕ БЕЗОПАСНОСТИ (бесигйу іеѕйпо) 


Одна из знакомых моего друга несколько лет назад наотрез от- 
казывалась пользоваться Интернетом. На вопрос "почему? " она 
неизменно отвечала, что боится хукеров, чем неизменно вызывала 
у окружающих смех до икоты, так как на самом деле она имела 
в виду хакеров (раскег — в современном значении киберпреступ- 
ник, поокег — девушка легкого поведения). 


Шутки шутками, а киберпреступность (суБег сгіте) — это целая 
криминальная индустрия, доходы ежегодно измеряются милли- 
ардами долларов, которые соответственно теряют корпорации и 
честные каптруженики. 


Тестирование безопасности — это множество вещей, суть кото- 
рых заключается в том, чтобы усложнить условия для кражи — 
кражи данных, денег и информации. 


Например, в одной из систем интернет-платежей есть специальный 
отдел, который профессионально занимается взламыванием... своего 
же веб-сайта и получает премии за каждую найденную ошибку в сис- 
теме обеспечения безопасности. 


ТЕСТИРОВАНИЕ ОПЫТА ПОЛЬЗОВАТЕЛЯ 
(изаБИиу іеѕіпе) 


Призвано объективно оценить опыт пользователя (иѕег ехрегіепсе), 
который будет работать с разрабатываемым интерфейсом. 


Каждый из нас иногда ломает голову над тем, как исполнить же- 
лаемое на том или ином сайте. Поясню. 


Допустим, вы идете на сайт сети пиццерий и хотите найти 
пиццерию, ближайшую к вашему дому. Если интерфейс сделан с 
заботой об опыте пользователя (иѕег рлеп@ у ітіегјасе), то мы 
быстро найдем вверху (һеайег) и/или внизу (јооіег) страницы 
хорошо заметный линк "ғеѕіаиғапі Іосаіот" либо "ѕіоғе Іосаіот" 
(месторасположение ресторана). 


Вопрос: почему такой линк должен быть вверху или внизу стра- 
ницы и называться именно так? 
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Ответ: да потому, что это своего рода конвенция, и пользователь, 
ищущий ближайшую к дому пиццерию, ожидает увидеть линк в 
этих местах и с таким названием. 


При юзабилити-тестировании также проверяется интуитивность 
интерфейса. Я видел некоторые "гениальные" интерфейсы, кото- 
рые словно были созданы с целью не допустить достижения 
страницы, на которой можно оплатить товар. 


Еще одним примером ужасного юзабилити является ставшее 
популярным размещение, скажем, на новостных сайтах больших 
мигающих баннеров справа от текста, после минуты чтения 
новостей на таком сайте создается впечатление, что побывал 
на угарной дискотеке. 


Юзабилити-тестирование часто проводится путем привлечения 
группы потенциальных пользователей с целью собрать впечатле- 
ния от работы с системой. 


В добрые доткомовские времена, на рубеже тысячелетий пред- 
ставители интернет-компаний запросто ловили на улицах Сан- 
Франциско праздношатающихся разгшъдяев и платили им 50 долл. 
за час работы со свежеиспеченным веб-сайтом. Тлоѕе меге ше 
ИЙ’ауз, ту јтіепа... Трое меге ше аауу... (непереводимо). 


Зачастую опыт пользователя тестируется самими продюсерами 
во время написания спека и создания макетов. Есть также про- 
фессиональные юзабилити-инженеры. 


ТЕСТИРОВАНИЕ СОВМЕСТИМОСТИ 
(сотрайБИйу 1езипэ) 


Это проверка того, как наш веб-сайт взаимодействует С 


• "железом" (например, модемами) и 
• ПО (браузерами/операционными системами) наших поль- 
зователей. 


Пример 


Много лет назад, когда №ъ№іѕсаре Мамдаг все еще использовался, а 
Виндоуз была еще в 98 версии, мы нашли такой баг: 


"Краткое описание: 


"Проблема совместимости: //іп'98 перезагружается при входе в 
систему с Меіѕсаре Мауюаг версии Х.Х" 
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Описание и шаги для воспроизведения проблемы: 


1. Открой имму. таіп.іеѕіѕһор.гѕ с помощью М№еіѕсаре Мамдаюг вер- 
сии Х.Х, установленной на И/п'98 (можно использовать машину 
из тест-лаборатории). 

2. Введи "гзаит-езшзег1 1@\е5{5пор.гз" в поле "Имя пользователя" 
и "121212" в поле "Пароль". 

3. Нажми на кнопку "Вход". 


Баг: И/п' 98 начинает перезагружаться. 
Ожидаемый результат: вход в систему. 


Комментарий: 
баг воспроизводится только при таком сочетании браузера и ОС". 


Из примера почерпнем по крайней мере три вещи: 


• при тестировании было найдено такое сочетание браузе- 
ра/операционной системы, при котором существовал фа- 
тальный баг, из-за которого пользователь не только не 
смог бы войти в ууу. таіп. іеѕіѕћор.тѕ, но и терял бы всю 
свою несохраненную работу; 

• проблемы, связанные с совместимостью между веб-сайтом 
и браузером/ОС, реальны и могут вести к серьезным багам; 

• можно (и нужно) создать тест-лабораторию с наиболее по- 
пулярными сочетаниями браузер/ОС, установленными на 
компьютерах наших пользователей. 


Как найти эти популярные сочетания? Очень просто — покопайтесь 
в Интернете и поищите статистику о пользовании браузеров и ОС. 


Что дальше? Дальше включаем компы с популярными ОС, запус- 
каем на них популярные браузеры и исполняем наши тест-кейсы. 


Тестирование с разными браузерами называется кросс-браузер- 
тестированием (сгоѕѕ-Рғгоуѕег іеѕііпо). 


Тестирование с разными ОС называется кросс-платформ-тести- 
рованием (сгоѕѕ-ріаіогт іеѕііпо). 


Примером тестирования совместимости вашего сайта и "железа" явля- 
ется ситуация, когда полноценное пользование вашим сайтом возможно 
только при наличии видеокарты определенного типа, например поддер- 
живающей технологию РіесіХ версии Х.Х. Здесь мы можем, например, 
протестировать, каков будет опыт пользователя, если у того на машине 
установлена устаревшая и неподдерживаемая видеокарта (кстати, такое 
тестирование будет называться негативным, но об этом позднее). 


За исключением тех случаев, когда тест-кейсы специально созда- 
ны для тестирования совместимости, я не рекомендую указывать 
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в них детали, например, по типу и версии браузера, так как типы 
и особенно версии меняются. Как мы помним, излишняя детали- 
зация приводит к трате времени на поддержание тест-кейсов. 


3. По субъекту тестирования 


• альфа-тестировщик (арйа іеѕіег); 
• бета-тестировщик (Реѓа 1еяет). 


АЛЬФА-ТЕСТИРОВЩИК (а/рћа ее) 


Это сотрудники компании, которые профессионально или непро- 
фессионально проводят тестирование: тестировщики, програм- 
мисты, продюсеры, бухгалтеры, сисадмины, секретарши. В стар- 
тапах накануне релиза нередко все работники, включая Харито- 
ныча, сидят по 16 часов кряду, пытаясь найти непойманные баги. 


БЕТА-ТЕСТИРОВЩИК (фе іеѕіег) 


Это нередко баловень судьбы, который не является сотрудником 
компании и которому посчастливилось пользоваться новой сис- 
темой до того, как она станет доступна всем остальным. За бета- 
тестирование иногда даже платят деньги (вспомните пример с 50 
долл. в час за юзабилити-тестирование). 


4. По времени проведения тестирования 


ДО передачи пользователю — альфа-тестирование (а/рћа 
1е5 тэ): 


• тест приемки (5токе іеѕі, запИу ѓіеѕі или сопйаепсе 1е51); 

• тестирования новых функциональностей (пеу јгаѓиғе 
іеѕіпе); 

• регрессивное тестирование (геогеѕѕіоп іеѕііпо); 

• тест сдачи (ассеріапсе или сегіўйсайоп е5), 


ПОСЛЕ передачи пользователю — бета-тестирование (Беа 
1е5 п) 


О "До передачи пользователю — альфа-тестирование (а/рйа іеѕі- 
тв)" мы еще поговорим. 


О "После передачи пользователю — бета-тестирование (реѓа ѓеѕі- 
тя)" уже говорили. 
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5. По критерию 
"позитивности" сценариев 


• позитивное тестирование (роѕііїуе 1езйиз); 
• негативное тестирование (песайуе іеѕіїпо). 


Начнем со второго. 


Пример 


Допустим, что имя файла с банковскими транзакциями должно иметь 
определенный формат: 


Боїа < УУУУММОР> асп. їхі 


где УУУУ — это год в полном формате (2005), ММ — это месяц в полном 
формате (01 — январь), ОБ — это день в полном формате (01 — первое 
число месяца). 


Этот файл служит в качестве ввода для программы ргосеѕѕ ігапѕасіопѕ, 
которая ежедневно в 23:00 


автоматически "забирает" его из директории Итр/приЁ йе5/, 
анализирует (рагѕе) его и 
вставляет данные из него в базу данных. 


Предположим, что из-за ошибки кода, генерирующего файл, имя фай- 
ла от 18 января 2004 г. будет не 


• роѓа 20040118 асһ.їхї (ргосеѕѕігапѕасііопѕ ожидает именно и 
буквально это имя), а 
• роїа 2004118 аспһ.іхі. 


Какая реакция должна быть у программы ргосеѕѕ {апзасйоп$, если 
она не может найти файл? 


Ответ на этот вопрос может быть найден в спеке, где, например, может 
быть указано, что в ситуации, когда файл не найден, ргосеѕѕ_ апзас- 
іопѕ посылает соответствующему дистрибутивному списку е-мейл: 


• с предметом (е-тай ѕибјесі) "Ошибка: файл ввода для ргос- 
еѕѕ іғапѕасііопѕ отсутствует" и 

• содержанием (е-тай Боду) "Файл Боға 20040118 асһ.іхі 
отсутствует е директории /тр/іприё #1е5/". 


Если спек не предусматривает возможности возникновения такой си- 
туации, то мы как тестировщики должны ее предусмотреть и создать 
тест-кейс с соответствующим сценарием. 

Итак, сценарий, проверяющий ситуацию, связанную с 


• потенциальной ошибкой (етот) пользователя и/или 
• потенциальным дефектом (аЙиге) в системе, 


называется негативным. 
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Пример ошибки пользователя 
Вводнедействительных данных в поле "Имя" на странице регистрации. 


Пример дефекта в системе 
Вышеуказанный пример о неправильной генерации имени файла. 


Создание и исполнение тест-кейсов с негативными сценариями 
называется НЕГАТИВНЫМ тестированием. 


Далее. 


Позитивные сценарии — это сценарии, предполагающие нор- 
мальное, "правильное" 


использование и/или 
работу системы. 


Первый пример позитивного сценария 
Ввод действительных данных в поле "Имя" на странице регистрации. 


Второй пример позитивного сценария 


Проверка работы системы, когда имя файла имеет правильный фор- 
мат: Боѓа 200401 18 асһ.їхі. 


Создание и исполнение тест-кейсов с позитивными сценариями 
называется ПОЗИТИВНЫМ тестированием. 


Несколько мыслей вдогонку: 


а. 


б. 


Как правило, негативное тестирование находит больше 
багов. 

Как правило, негативное тестирование — вещь более слож 
ная, творческая и трудоемкая, так как спеки описывают, 
как должно работать, когда "усе в порядке", а не как долж 
но работать в ситуациях с ошибками или сбоями. 

Если есть позитивные и негативные тесты как часть тест- 
комплекта, то позитивные тесты исполняются в первую 
очередь. Логика: 

В большинстве случаев целью создания функционачьности 
является возможность реализации именно позитивных 
сценариев, т.е. работоспособность позитивных сценариев 
более приоритетна, чем работоспособность негативных 
сценариев. 

Существуют спеки, полностью посвященные тому, как долж 
на себя вести система при ошибках/дефектах. Следователь 
но, все тестирование такого спека будет негативным. 
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Д. Два полезных термина: 


• обращение с ошибкой/дефектом (е’тог йапаЙи® /јайиғе 
һапаіпе) — это то, как система реагирует на ошиб- 
ку/дефект; 

• сообщение об ошибке (е’тог теззазе) — это информа- 
ция (как правило, текстовая), которая выдается пользо- 
вателю в случае ошибки/сбоя. 


Маленький примерчик вдогонку 


Правильность сообщений об ошибке является намного более серьез- 
ной вещью, чем может показаться, при рассуждениях об этом в теории. 
Например, сегодня я попытался купить по Интернету новую книгу Хару- 
ки Мураками: 


• добавил книгу в корзину на одном из сайтов, 
• вбил номер кредитки в соответствующие поля веб-страницы и 
• нажал кнопку "Купить". 


Мне выдается сообщение об ошибке: так, мол, и так, проверьте, пожа- 
луйста, номер своей кредитной карты, дорогой пользователь. Я про- 
веряю — все в порядке: и номер карты, и срок действия. Нажимаю 
"Купить" еще раз — го же сообщение об ошибке. Пробую вбить инфор- 
мацию по другой карте — то же самое. Начиная с этого момента, 
успешное осуществление акции покупки новой книги Харуки Мура- 
ками стало для меня делом принципа. Звоню в службу поддержки, и 
мне говорят 


— А вы, кстати, поставили галочку в чек-бокс (сһеск Бох), что 
согласны 

с нашим соглашением? 

-Нет. 

— А вы поставьте и попробуйте нажать на кнопку "Купить". 

— Ставлю, пробую, работает. 

— Ну вот и славненько. Чем-нибудь еще можем быть полезны? 

— Ничем. Тћапк уои. 


В итоге я потерял 15 минут своего времени, а веб-сайт потерял меня 
как пользователя, так как "ложечки нашлись, а осадок остался". Все 
из-за неверного сообщения об ошибке. 


6. По степени изолированности 
тестируемых компонентов 


• компонентное тестирование (сотропепі іеѕіїпе); 

• интеграционное тестирование (іпіеогайоп іеѕііпо); 

• системное (или энд-ту-энд) тестирование (5уѕѓеи ог 
еп4-ю-епа іеѕііпе). 


Сначала краткие и емкие определения, а затем иллюстрации. 
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Компонентное тестирование (сотропепі іеѕііпе) — это тестиро- 
вание на уровне логического компонента. И это тестирование 
самого логического компонента. 


Интеграционное тестирование (йиестайоп 1е5Нпз) — это тести- 
рование на уровне двух или больше компонентов. И это тестиро- 
вание взаимодействия этих двух или больше компонентов. 


Системное (или энд-ту-энд) тестирование (ѕуѕіет ог епа-ю-еп4 
1е5Ипе) — это проверка всей системы от начала до конца. 


Теперь иллюстрации кратких и емких определений. 


Допустим, программисту поставлена задача написать код, который 
бы находил полные имена и е-мейлы пользователей, потра- 
тивших больше 1000 долл. в нашем онлайн-магазине с момента 
регистрации. Таким пользователям должен быть отправлен е-мейл 
с подарочным сертификатом, использование которого до 17 но- 
ября включительно предоставит 5%-ю скидку на любую разовую 
покупку. 


Кстати, для добротного тестирования данной функциональности нужно 
написать гораздо больше тест-кейсов, чем я приведу, но сейчас наша 
задача — это понять 


суть каждого из трех рассматриваемых видов тестирования и 
разницу между ними. 


КОМПОНЕНТНОЕ ТЕСТИРОВАНИЕ 


Для начала выделим три компонента, которые мы протестиро- 
вали бы: 


1. Создание файла с полными именами, е-мейлами и номера- 
ми сертификатов. 

2. Рассылка пользователям е-мейлов. 

3. Правильное предоставление скидки вышеуказанным поль- 
зователям. 


Проверяем. 
Компонент 1 


Проверяем, что создается файл нужного формата 


• сполными именами и е-мейлами пользователей, потратив- 
ших > 1000 долл., и 
• номером сертификата для каждого из этих пользователей. 
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Это позитивное тестирование. 


Мы также должны проверить, не затесались ли в наш файл 


пользователи, потратившие < 1000 долл. 


Это негативное тестирование, связанное с потенциальным дефек- 
том в коде, отвечающем за выбор правильных пользователей. 


Компонент 2 


Допустим, код первого компонента, который должен был создать 
для нас файл, не работает. Мы не отчаиваемся, а просто вручную, 
не ропща на судьбу, создаем файл установленного формата с взя- 
тыми с потолка 

• е-мейлами, 

• полными именами пользователей и 

• номерами подарочных сертификатов. 


Этот файл мы "скармливаем" программе рассылки е-мейлов и 
проверяем, что правильные е-мейлы доходят до пользователей из 
файла(позитивное тестирование). 


Компонент 3 
Как мы помним, компонент 1 не работает. Что делать? 


Сертификат — это как некий код, например "ОҮТО764587657". 
который нужно ввести во время оплаты, и если сертификат дей- 
ствительный, то итоговая сумма к оплате уменьшается. 


В данном случае можно попросить программиста, чтобы тот по- 
мог сгенерировать легитимные номера сертификатов. Когда но- 
мера сертификатов имеются в наличии, можно, например, прове- 
рить, работает ли подарочный сертификат только один раз (пози- 
тивное тестирование) или его можно использовать для двух или 
более транзакций (негативное тестирование, воспроизводящее 
ошибку пользователя, использующего сертификат более одного 
раза). Также нужно будет проверить размер скидки (5%) (пози- 
тивное тестирование) и действительность сертификата: 


до 17 ноября (позитивное тестирование), 17 

ноября (позитивное тестирование) и 

после 17 ноября (негативное тестирование, воспроизводящее 
ошибку пользователя, использующего просроченный сер- 
тификат). 
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Кстати, в случаях когда тестирование связано со сроками (например, 
сроком истечения сертификата), мы, естественно, не ждем до 17 но- 
ября, а просто меняем системное время тест-машины на нужное время 
или меняем значение времени в базе данных. Естественно, что такие 
изменения вы должны предварительно согласовать с коллегами, кото- 
рые работают на той же тест-машине или с той же базой данных. 


Важный момент: хотя по спеку все три компонента и взаимосвя- 
заны, из-за проблем в коде у нас получилось компонентное тес- 
тирование в чистом виде. Другими словами, мы тестировали са- 
ми компоненты, а не связь между ними. 


Тестирование связи между компонентами называется интегра- 
ционным тестированием. 


ИНТЕГРАЦИОННОЕ ТЕСТИРОВАНИЕ 


У нас есть три связи между компонентами: 


а) между 1-м и 2-м компонентами; 
б) между 2-м и 3-м компонентами; 
в) между 1-м и 3-м компонентами. 


Подробности: 
а. Компонент 1 генерирует файл со списком 


• е-мейлов и полных имен подходящих пользователей и 
• номерами сертификатов. 


Этот список используется компонентом 2, который ответ- 
ствен за рассылку е-мейлов. 


б. Компонент 2 доставляет пользователю в качестве е-мейла 
информацию о подарочном сертификате. Пользователь 
может использовать сертификат (компонент 3), только ес 
ли он знает правильный номер своего сертификата. 

в. Компонент 1 генерирует код сертификата, который ис 
пользуется компонентом 3. 


Итак, в нашем случае при интеграционном тестировании у нас 
есть для проверки 3 связи. Приведем примеры соответствующих 
тестов на интеграцию. 


а. Здесь можно проверить, совместим ли формат файла, соз- 
данного компонентом 1, с программой рассылки компонента 2. 
Например, последняя принимает следующий формат файла: 


полное имя пользователя, е-мейл, номер сертификата. 
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Значения отделены друг от друга запятой (сотта-4ейтиеа). Ин- 
формация о каждом новом пользователе — на новой строчке. 
Сам файл — простой текстовый файл, который можно открыть 
программой №оѓераа. 


Образец файла: 


Еегатапао МавеПапо, ртазеЦНапо@лтааа.рь ОТ’ЕКТ98362 
Јатеѕ Соок, јатеѕ.соок@епаеауоиг.со.ик, АЗОЕО54209 Иван 
Крузенштерн, ікғигепѕіегт(падејаа.ғи, 1КЈНС61123 


Допустим, программист ошибочно заложил в коде, что значения 
файла разделяются не запятой (форматом, принимаемым про- 
граммой рассылки), а точкой с запятой: 


Еег4тапао МавеПапо; ЃтавеПапо@ітіпійаа.рі; ОЙ’ЕКТ98362 
Јатеѕ Соок; јатеѕ.соок@епаеауоиг.со.ик; А8$"0Е@54209 Иван 
Крузенштерн; ікғигепѕіегт(пааејаа.ғи; ГКУНС61123 


Когда мы проводим интеграционный тест, мы обнаруживаем, что 
программа рассылки не принимает файл неподходящего формата, 
и соответственно никакие е-мейлы до пользователей не дойдут, 
если этот баг не будет устранен. 


б. В данном случае у нас может быть ситуация, когда файл 
имеет верный номер сертификата, но из-за бага в программе рас 
сылки пользователь получает е-мейл с "неправильным" номером 
сертификата. 


Это может произойти из-за того, что программа рассылки 
может быть ошибочно сконфигурирована, чтобы "брать" 
только 9 первых символов из третьей колонки (колонки с номе- 
рами сертификатов), т.е. ОЙ’ЕКТ98362 будет преподнесена поль- 
зователю в укороченном виде (ігипсаїѓеа): ОЙ’ЕКТ9836. 


Интеграционный тест по использованию номера сертификата, 
полученного по е-мейлу, может выявить этот баг. 


В. Здесь может быть ситуация, когда номер сертификата, сгене 
рированный компонентом 1, не принимается компонентом 3. 


Пример такой ситуации 

Компонент 1 сохранил номер сертификата в базе данных в зашифро- 
ванном виде, т.е. в целях безопасности использовался алгоритм, кото- 
рый превратил "1КУНС61123", например, в "*&"(*&86%(987$!$#". Из-за 
бага в компоненте 3 последний не дешифровал номер сертификата, 
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взятый из БД, а просто попытался сравнить эту абракадабру из БД и 
номер сертификата, введенный пользователем, что привело к тому, 
что номера не сошлись и легитимная скидка не была предоставлена. 


Должен ли был быть номер сертификата зашифрован или нет, для 
нас сейчас значения не имеет. Значение имеет тот факт, что баг 
был обнаружен во время интеграционного тестирования. 


СИСТЕМНОЕ ТЕСТИРОВАНИЕ 


Это тестирование системы (функциональности) от начала до 
конца (еп -ю-епа), т.е. каждый сценарий будет затрагивать всю 
цепочку: компонент 1 —> компонент 2 —> компонент 3. 


Я рекомендую ставить простой тест-кейс с системным тестом 
в самое начало тест-комплекта. Так можно сразу увидеть, если 
что-то явно не в порядке. Это своего рода тест приемки непосред- 
ственно для вещи, тестируемой данным тест-комплектом. 


Хорошая идея вдогонку 
Е-мейл состоит из следующих частей: 


е-мейла алиаса; 

собаки; 

домена почтового сервера; 

точки; 

глобального домена. 
В вашем рабочем е-мейле алиасом будет, как правило, ваши имя (или 
инициал) и фамилия: гзаут. 
Собака остается собакой, хотя по-аглицки она называется 'аї" (читает- 
ся как "эт"): 

@ Доменом почтового сервера будет домен 


компании: 
{е55Пор 


Точка остается точкой, хотя по-аглицки она называется "дої" (читается 
как "дот"): 


Глобальный домен — это зона домена компании, например "сот" или "ги": 
г, 

т.е. получаем: гѕауіп@їеѕіѕһор.г= 

При тестировании интернет-проектов приходится создавать много сче- 

тов пользователей. Загвоздка в том, что е-мейл пользователя, который 

очень часто является его именем, может быть использован только один 


раз, т.е. мой рабочий е-мейл гѕамиіп@іеѕіѕһор.ғ= может быть использо- 
ван для создания только одного счета. 
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Что делать? Открывать бесчисленные счета на хотмейлах и яху? Ответ 
неверный. 


Самая хорошая идея: поговорите с администратором почтового сер- 
вера вашей компании, чтобы он модифицировал настройки сервера 
так, чтобы к вам приходили все е-мейлы следующего формата: 


гѕауіп+ѕотеѓехі@іеѕіѕһор. гѕ, 


т. е. после моего алиаса стоит знак плюс и между знаком плюс и соба- 
кой находятся любые легитимные знаки. 


Например, для тестирования компонента 1 я регистрируюсь с е-мейлом: 
гѕауіп+сотропепії_їеѕ@їеѕіѕһор.гѕ 


Таким образом, вы можете создавать тысячи эккаунтов пользователей 
своего сайта, не регистрируя тысяч новых е-мейл-эккаунтов. 


Рекомендую. Очень удобно. 


7. По степени автоматизированное"" 
тестирования 


• ручное тестирование (тапиа! іеѕііпо); 

• автоматизированное тестирование (аиіотаіей іеѕііпо); 

• смешанное / полуавтоматизированное тестирование 
(сет аиіотаїеа іеѕііпе). 


О каждом из трех "друзей" будет еще сказано очень много и в 
подробностях. Пока же давайте поговорим концептуально. 


РУЧНОЕ ТЕСТИРОВАНИЕ 


Это исполнение тест-кейсов без помощи каких-либо программ, 
автоматизирующих вашу работу. Например, для того чтобы 
создать эккаунт нового пользователя, мы идем на наш 
уугу. таїп.іеѕіѕћор.ғѕ, открываем страницу регистрации, запол- 
няем формы и т.д. 


АВТОМАТИЗИРОВАННОЕ ТЕСТИРОВАНИЕ 


Это отдельная дисциплина искусства тестирования. Значительная 
часть эффективности работы отдела тестирования зависит от 
того, какие задачи отданы для автоматизации и как эта автома- 
тизация была осуществлена. Автоматизация может как принести 
огромное облегчение всем тестировщикам, так и завалить работу 
всего отдела и отложить релиз, премию, отпуск и другие сладкие 
вещи. 
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Оговорка 


Термин "тул" (юоГ(англ.) — инструмент) используется для обозначения 
компьютерной программы, как правило, вспомогательного свойства. 


Автоматизировать можно сотни вещей. Вот наиболее часто 
встречающиеся виды автоматизации: 


а. Тулы для помощи в черноящичном и сероящичном тес- 
тировании. 


Например, 


• тул, который автоматически создает для нас эккаунт поль- 
зователя; 

• тул, совершающий запросы к базе данных и генерирующий 
файлы формата, утвержденного системой ИА, используя 
извлеченные данные; 

• тул, генерирующий транзакции покупки в нашем магазине, 
ит.д. и т.п. 


Вариантам нет конца и края. Такие тулы пишутся программиста- 
ми компании или самими тестировщиками. 


Пример тула, создающего эккаунты пользователя 


Если набрать в браузере им. таіп.іеѕіѕһор.г5/ооІ5/гедіѕіег.ру (это 
все, естественно, гипотетически, так как такого сайта в природе не су- 
ществует), то мы увидим не 10 обязательных полей, которые нужно за- 
полнить, а одно текстовое поле и кнопку "создать тест-эккаунт". Вы 
просто вводите уникальный е-мейл нового пользователя, например 
гѕауіп-іеѕіиѕег1000@іеѕіѕһор.гѕ, и нажимаете на кнопку. Тул делает за 
вас все остальное. Пароль для всех эккаунтов будет, например "898989". 


Хорошая идея: 


используется автоматизация для создания новых эккаунтов или 
нет, очень удобно, когда в компании существует конвенция для 
одного пароля при создании тест-эккаунтов, например "898989". 


Дело в том, что иногда нет времени/возможности создать эккаунт 
С определенными транзакциями, настройками и т.д., и если такой 
эккаунт уже существует, то, зная пароль, вы сможете им воспользо- 
ваться. 


При этом помните о деловой этике, и если этот эккаунт создан не вами, 
то по возможности вежливо спросите у "хозяина" эккаунта разрешение. 


б. Программы для регрессивного тестирования 


Это специальное ПО, созданное для буквального воспроизведе- 
ния действий тестировщика. 
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Пример 
Согласно тест-кейсу вы должны 
• войти в систему, 
• выбрать товар, 
• положить его в корзину, 
• заплатить и 
• удостовериться, что баланс на кредитной карте уменьшился на 
сумму покупки. 


Чтобы исполнить этот тесткейс, вы должны запустить браузер, ввести 
имя пользователя и пароль, нажать на кнопку "Вход"... и, в конце кон- 
цов, сравнить фактический и ожидаемый результаты. 


Теперь представьте себе, что некая программа делает те же самые 
действия, что и вы, т.е. сама запускает браузер, печатает, где положе- 
но, имя пользователя и пароль, нажимает на кнопку "Вход"... и, в коние 
кониов, сравнивает ожидаемый и фактический результат и сообщает 
вам о нем (через сообщение на экране, запись в файле, е-мейл и т.д.). 


Такое ПО, как правило, поддерживает режим "Запись / Воспроиз- 
ведение", т.е. когда мы нажимаем на кнопку "Запись" и начинаем 
кликать мышками и клацать клавишами клавиатуры, ПО записы- 
вает наши действия и, когда мы закончили, генерирует код. Этот 
код мы можем запустить с этим же ПО, и оно воспроизведет все 
наши клики и клацы, т.е. буквально будет водить курсором мыш- 
ки, набирать текст и т.д. 


Такое ПО, как правило, имеет собственный язык программиро- 
вания, т.е. можно не записывать свои действия, а непосредст- 
венно написать код, что и делается теми, кто профессионально 
работает с таким ПО. 


Наиболее популярная и мощная программа для автоматизации 
регрессивного тестирования веб-проектов — это 5И Тез, выпус- 
каемый компанией $ерие. 


У нас будет отдельная беседа о хороших и плохих вещах, связан- 
ных С автоматизацией регрессивного тестирования. 


в. Программы для тестирования скорости и надежности 


О таком ПО мы уже говорили. И так как ѕ/еѕѕ//оаа/регоғтапсе 
іеѕііпе — это песня не нашего черно-сероящичного репертуара, 
петь, т.е. говорить, о них больше не будем. 


г. Прочие программы 


Это, например, "Проверяльщики линков" (Пик слескегѕ). 
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СМЕШАННОЕ/ПОЛУАВТОМАТИЗИРОВАННОЕ 
ТЕСТИРОВАНИЕ 


Здесь ручной подход сочетается с автоматизированным. Напри- 
мер, с помощью тула я создаю НОВЫЙ эккаунт и потом вручную 
генерирую транзакцию покупки. 


8. По степени подготовки к тестированию 


• тестирование по тест-кейсам (Фоситепіей іеѕііпе); 
• интуитивное тестирование (а4 рос іеѕііпа). 


Здесь все просто. Есть тестирование по тест-кейсам, а есть тести- 
рование а4 рос (лат. — для этой цели, читается как "эд-хок"), т.е. 
мы просто интуитивно роемся в ПО, пытаясь найти баги. Интуи- 
тивное тестирование, как правило, применятся: 


• тестировщиком в качестве теста приемки и/или теста сдачи 
(если тест-кейсы для них не формализованы в документации); 

• тестировщиком в качестве успокаивающего для сердца в 
довесок к документированным тестированию новых функ- 
циональностей и регрессивному тестированию; 

• тестировщиком, который только что пришел в компанию, 
где код уже написан и нужно срочно все протестировать; 

• когда бухгалтерия и менеджмент протягивают тестиров- 
щикам руку помощи перед релизом; 

• в других случаях, когда нет тест-кейсов. 


Нужно отметить, что эд хок-тестирование часто дает поразитель- 
ные результаты: бывает, исполняешь только что пришедшие в 
голову сценарии, которые и не снились при подготовке к тестиро- 
ванию, и находишь дородные, розовощекие и ухмыляющиеся баги. 


Краткое подведение итогов 


1. Мы классифицировали основные виды тестирования в интернет- 
компаниях. 

2. Мы узнали о трех основных подходах к тестированию: "Черный 
ящик", "Белый ящик" и "Серый ящик". Водораздел между ними 
лежит в плоскостях степени знания о внутренностях системы и 
ориентированности на надежды и чаяния конечного пользователя. 

3. Мы узнали, что паттерн поведения пользователя составляют 
сценарии и данные для них (хотя мы стали все это вместе на- 
зывать сценариями). 
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10. 


11. 


12. 


13. 
14. 


Тестирование Дот Ком. Часть 2 


Мы узнали об основных источниках знания о потенциальных 
паттернах поведения пользователей. 

Мы узнали концепцию тестировочного покрытия. 

Мы узнали, что количественное и качественное тестирование 
обеспечивается путем слияния в оргазме черноящичных и бело- 
ящичных методик тестирования. 

Мы узнали, что мало быть хорошим человеком. Надо еще по- 
нимать, какой ожидаемый вывод является тем самым ожидае- 
мым результатом, который приведет нас к реальному тести- 
рованию. 

Мы поняли разницу между тестированием интерфейса поль- 
зователя и тестированием с помощью интерфейса пользо- 
вателя. 

Мы удивились, узнав, что код, прекрасно работающий функ- 
ционально, может привести к сбою в работе веб-сайта (про- 
блемы перформанса). 

Мы прочувствовали, что несовместимость — это проблема не 
только человеческих отношений, но и отношений нашего сайта с 
"железом" и ПО пользователя. 

Мы запомнили, что, как правило, позитивные тесты исполняются 
в первую очередь. 

Мы прошли шаг за шагом от компонентного до системного тес- 
тирования. 

Мы разобрались в видах автоматизации. 

Мы отметили, что интуитивное (эд хок) тестирование иногда 
приносит превосходные результаты. 


Задание для самопроверки 


Приведите, пожалуйста, классификацию видов тестирования с оп- 
ределением каждого из них. 


ЧАСТЬ 3 


ПОДГОТОВКА К ТЕСТИРОВАНИЮ 


. НИГИЛИСТИЧЕСКИЙ НАСТРОЙ 
И ПРАКТИЧЕСКАЯ МЕТОДОЛОГИЯ 


ИСПОЛНЕНИЕ ТЕСТИРОВАНИЯ 
ЖИЗНЬ ЗАМЕЧАТЕЛЬНЫХ БАГОВ 


ИСПОЛНЕНИЕ ТЕСТИРОВАНИЯ. 
СТАДИЯ 1: ТЕСТИРОВАНИЕ НОВЫХ ФИЧА 
(Меи Ееашге Теѕїіпд) 


• ИСПОЛНЕНИЕ ТЕСТИРОВАНИЯ. 
СТАДИЯ 2: РЕГРЕССИВНОЕ ТЕСТИРОВАНИЕ 
(Редгеѕѕіоп Теѕіпд) 


— Возвращай- 
тесь, когда выучите 


=| теорию аргумента- 


Л 


РА 


— Теория суха, мой 
друг, а древо жизни 
вечно зеленеет 

< 


ЭКЗАМЕН 
по 


ПОДГОТОВКА К ТЕСТИРОВАНИЮ 


НИГИЛИСТИЧЕСКИЙ НАСТРОЙ И 
ПРАКТИЧЕСКАЯ МЕТОДОЛОГИЯ 


• МЕНТАЛЬНЫЙ НАСТРОЙ ТЕСТИРОВЩИКА 
• МЕТОДЫ ГЕНЕРИРОВАНИЯ ТЕСТОВ 
• МЕТОДЫ ОТБОРА ТЕСТОВ 


| ў одготовка к тестированию с точки зрения тестировщика 
включает: 


1. Написание новых тест-кейсов и/или 
2. Изменение существующих тест-кейсов и/или 
3. Удаление существующих тест-кейсов. 


Иногда требуется создание/модификация тест-тулов, но об этом 
мы здесь говорить не будем, так как фактически тест-тулы — это 
чистой воды программирование, облегчающее исполнение тест-кейсов. 


Кстати, дни начала и завершения подготовки к тестированию указаны в 
расписании тестирования ($ ѕсһеаиІе), которое является публичной (в 
пределах компании) информацией. Таким образом, тестиров-щик может 
рассчитывать свои силы, т.е. уходить с работы в 4 дня или 4 утра в 
зависимости от достигнутого им прогресса. 


Постановка мозгов 


Многие вещи, о которых мы будем говорить, могут показаться теоретиче- 
ски простыми, но пусть эта псевдопростота не вводит вас в заблуждение. 


Приведем аналогию с шахматами. Взрослому человеку нужно 5 минут, чтобы 
запомнить правила (как ходят/бьют пешки и фигуры, правила рокировки и 
пр.), а для того чтобы стать мастером игры, нужны сотни сыгранных партий. 


То же самое и с методами тестирования: понять базовые элементы и 
концепции особого труда не составит. Для того же, чтобы стать эффек- 
тивным профессионалом, понадобятся месяцы и годы практического 
применения этих элементов и концепций на реальном ПО. 
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Для тестировщика подготовка к тестированию — это наибо- 
лее сложный, творческий и интересный процесс. 


Венцом этого процесса являются тест-кейсы, которые после их 
исполнения на стадии "Исполнение тестирования" смогли бы 
превентировать встречу пользователей и багов. 


Мы — ловцы. И тест-кейсы — это сеть, которую мы 

. плетем (подготовка к тестированию) и 

• используем (исполнение тестирования). 
Как мы помним, тест-кейс содержательно состоит по крайней мере 
из ожидаемого результата, но, как правило, это комбинация: 


• идеи тест-кейса, 
• сценария и 
• ожидаемого результата. 


И те, и другие, и третьи можно почерпнуть из множества источ- 
НИКОВ: 


• спеков, 
• опыта, 

• эксплоринга, 
• общения, 


• ИНТУИЦИИ И 
• других кладезей информации. 


Вопрос: что отличает тестировщиков от других участников про- 
цесса разработки ПО, которые тоже могут придумать тест-кейсы, 
основываясь на спеках, опыте, эксплоринге и т.д.? Ответ: 
отличают нас две профессиональные вещи: 


• ментальный настрой; 
• инструментарий, т.е. прикладные знания. 


Сначала о ментальном настрое замолвим мы слово. 


Ментальный настрой тестировщика 


Помните наблюдение, что, попадая в лес, 
• плотник видит доски, 
• художник — пейзажи, а 
• биолог — материал для диссертации? 


Нигилистический настрой и практическая методология 175 


Так вот, 


• для пользователя код — это инструмент для выполнения 
каких-либо неотложных задач (например, покупки устрой- 
ства для подзаводки автоматических часов); 

• для продюсера — реализация гениальных идей менедж- 
мента, увековеченных в спеке; 

• для программиста — кусок хлеба с черной икрой; 

• для тестировщика код — это убежище багов. 


Постулат "б$оЙиаге пах Бирѕ" ("ПО содержит баги") — это не 
выдумка лицемеров и лжесвидетелей, а вселенский закон, кор- 
мящий тестировщиков, а следовательно, и их жен, детей, говоря- 
щих попугаев и лысых кошек. Не будем же лишать наших домо- 
чадцев лакомого куска и раскроем свое сердце истинной сути ве- 
щей, заключающейся в том, что ПО своей природе — это баго- 
содержащее и неблагонадежное существо. 


Еще раз: 
код — это убежище багов. 


Итак, навесив ярлыки, идем дальше... 


Как известно, ищущий да обрящет (из этого не следует, что не 
ищущий не сможет обрести. Однако логичнее предположить, что 
именно тот, кто ищет, найдет больше. По крайней мере, как 
правило...). 


Тестирование — это ПОИСК багов. 


"ПОИСК" — это ключевое слово, точно раскрывающее смысл 
нашей профессии, которая принципиально требует от нас, как и 
от сыщиков, и прикладных знаний, и интуиции, и ментальных 
установок. 


Постановка мозгов 


Концепция "поиска багов" как пути, по которому идет тестировщик для 
превентирования свидания пользователя и багов, начисто отметает 
идею о том, что тестировщик, подобно ОТК (отдел технического кон- 
троля в СССР), сертифицирует продукт на качество и ставит штамп 
"Проверено, багов нет". Ничего мы не сертифицируем, да и штампов 
у нас нет, кроме тех самых... в паспорте... 


Еще раз: основа работы тестировщика — это поиск багов. 
Тестировщик не занимается поиском доказательств того, что ПО 
работает. 
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Мы должны настроить себя на поиск багов в коде, который 
является убежищем этих самых багов. №Мсе апа йпр/е. 


Основой такого настроя — ментального настроя тестировщи- 
ка — является деструктивное мышление, полное подозритель- 
ности, недоверия и априорного отрицания даже потенциаль- 
ного наличия добродетелей — все в отношении ПО. Мы долж- 
ны твердо верить в то, что "был бы код, а баги найдутся". 


Пытливый ум внимательного слушателя сразу же сгенерирует 
вопрос, на который я тут же отвечу. 


Вопрос: «О каком деструктивном мышлении мы можем гово- 
рить, если у нас есть такое понятие, как "позитивное тестирова- 
ние", и позитивные тест-кейсы настолько важны, что мы испол- 
няем их в первую очередь?» 

Ответ: "Позитивное тестирование и принцип первичного испол- 
нения позитивных тест-кейсов — это технический аспект. Де- 
структивность в мышлении — это аспект ментальный. Даже если 
мы создаем тест-кейс с позитивным сценарием, мы должны ис- 


кать способ, чтобы обнаружить баги". 


Дорогие друзья! Взращивайте и лелейте в себе неисправимый пес- 
симизм в отношении идеи о коде, свободном от багов. 


Смотрите на код как на виртуальную вещь, которая в процессе 
тестирования послужит еще одним доказательством постулата о 
несовершенстве мира. Если вы настроите себя на деструктив- 
ное мышление в отношении кода, то ваша интуиция вклю- 
чится на всю катушку и прекрасные идеи для тест-кейсов 
будут стаями роиться в ваших головах, как только вы прочи- 
таете спек. 


Парочка сладких десертов 


— Скажите, а исполнится ли загаданное желание, если я загадаю его, 
сидя между двумя программистами? 
— Конечно, исполнится, но... будет глючить! 


Хирург, инженер и программист сидят в баре и обсуждают, чья про- 
фессия является древнейшей: 


Хирург: Моя профессия является древнейшей, потому что Богу нужны 
были знания по хирургии, чтобы извлечь из Адама ребро. 

Инженер: Но еще до этого был хаос, и, чтобы сделать мир из хаоса, 
Богу нужны были инженерные знания. 

Программист: Ха! Кто же, как вы думаете, создал весь этот хаос? 
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Теперь, настроенные и решительные, переходим к профессио- 
нальным прикладным знаниям, а именно к методологии соз- 
дания тест-кейсов ((е5сазе деѕіоп теіһоаоіору) (далее — мето- 
дология). 


В одной из прошлых бесед мы говорили 
о первой части методологии — формальной стороне построе- 
ния тест-кейса. 


Сегодня же речь пойдет 
о второй ее части — содержательной стороне тест-кейса. 


Искусство создания содержательной части тест-кейсов заключа- 
ется в нахождении тех "золотых" 


• идей тест-кейсов, 
• сценариев и 
• ожидаемых результатов, 


которые при исполнении тестирования помогли бы обнару- 
жить больные, багосодержащие места тестируемого ПО. 


Какие два этапа составляют процесс, называемый "выбор"? 


1. Сначала нам нужно увидеть, что имеется в наличии. 
2. Затем, используя некий критерий (-ии), мы выбираем или 
не выбираем. 


Например, выбирая щенка, 


1 мы должны увидеть одного или больше щенков (что имеется в на- 
личии) и затем 

2) посмотреть, как весело он (они) бегает, как блестят его глазенки 
и пр. И посмотрев, решить — брать или не брать. 


Подход К выбору сценариев концептуально схож: 


1. Что имеется в наличии, мы видим после использования 
методов генерирования тестов (тейо4$ о іеѕі сепегайоп); 

2. Орудиями отбора являются методы отбора тестов ((е51 ѕе- 
Іесііоп сгиетоп). 


Разв ертываем: 


Методы генерирования тестов: 


1. Черновик-чистовик (ту 151-ийие 1151); 
2. Матричная раскладка (таѓгісеѕ); 
3. Блок-схемы (Йомсрату. 
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Методы отбора тестов: 


1. Оценка риска (715 еѕйтаїѓе); 
2. Эквивалентные классы (едийете сіаѕѕезѕ); 
3. Пограничные значения (Боипаагу уаіиезѕ). 


Методы генерирования тестов 


1. Черновик-чистовик (7 [51-мййе 1152). 
2. Матричная раскладка (таігісеѕ). 
3. Блок-схемы (оусйаг!). 


1. "ЧЕРНОВИК-ЧИСТОВИК" 


Это самый простой и практичный метод. Суть проста. Два этапа: 
а. Черновик (у 151) 


В процессе (и/или после) прочтения спека, эксплоринга ПО и/или 
получения информации о ПО другим способом, не анализируя и 
отдавшись вдохновению и фантазии, мы просто набрасываем на 
лист бумаги (или в файл Ворда), являющийся черновиком (41? 
1151), ВСЕ идеи, связанные с тестированием, которые только могут 
прийти в голову, — идеи в самом широком смысле этого слова, 
включая идеи для тест-кейсов, сценарии, отдельные элементы 
сценариев (шаги и/или данные), ожидаемые результаты, вопросы 
для выяснения у продюсера и пр. 


Еще раз: ВСЕ идеи — даже самые на первый взгляд далекие от 
здравого смысла. Локальный мозговой штурм. 


б. Чистовик (мййе [5 


Затем мы начинаем анализировать написанное (и, если нужно, 
получать ответы на вопросы) и переносим на чистовик вещи, 
имеющие право на жизнь. Право на жизнь определяется на осно- 
вании информации из спека, общения, интуиции, критериев от- 
бора тестов, разговора с программистом и пр. При переносе на 
чистовик мы также уточняем наши идеи и группируем их (на- 
пример, по позитивности и негативности; по функциональным 
направлениям и т.п.). Таким образом, как правило, первый чисто- 
вик превращается во второй черновик, и мы берем следующий 
лист бумаги и, надеясь, что он будет чистовиком, начинаем пере- 
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носить на него наши идеи и т.д. В итоге в один из светлых май- 
ских дней мы все-таки получаем чистовик. На основании мате- 
риала из чистовика мы пишем тест-кейсы. 


Сейчас рекомендую вам немедленно взять ручку, лист бумаги и 
потратить 15 минут на генерацию черновика по тестированию 
автомата для продажи банок с колой (любимый тест рекрутеров 
из "Майкрософта"). Начинаем: 


Проверить, что покупателю выдается именно та банка, ко- 
торую он хочет. 

• А что, если покупатель нажмет на кнопку два раза? 

А что, если покупатель попробует наклонить аппарат, что- 
бы банки посыпались как из рога изобилия? 

Проверить, что правильно выдается сдача. 

• Какая реакция на монетку иностранного государства? 

• Итд. ити. 


После того как черновик готов, потратьте 15 минут на составле- 
ние чистовика и затем 30 минут на составление тест-кейсов по 
полной форме: 


• идея, 
• сценарий (шаги и данные) и 
• ожидаемый результат. 


Ручаюсь, что этот час окупится сторицей, чем бы вы ни занима- 
лись в жизни, и вы ни разу не пожалеете, что потратили 60 минут 
времени на подобный тренинг. 


2. МАТРИЧНАЯ РАСКЛАДКА 
Давайте без прелюдий и патетики перейдем к примеру. 


Украдем макет первой страницы регистрации из цикла разра- 
ботки ПО: 


Индекс места жительства“: | 


Продолжить регистрацию | 


ы поле обязательно для заполнения 


Сделаем матричную раскладку. 
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Этап 1. Набросок элементов (табл. 1) 


Таблица 1 
Набросок элементов 


Индекс 


Индекс эл 001 
Индекс эл 002 
Индекс эл 003 
Индекс эл 004 
Индекс эл 005 
Индекс эл 006 
Индекс эл 007 
Индекс эл 008 
Индекс эл 009 
Индекс эл 010 


Индекс введен? 


нет 


Индекс действующий? 


нет 

Значения индекса 
6 цифр 
5 цифр 


Включает буквы 


Включает специальные 
символы (например, &) 


Сосо В О В В И О 


Таким образом, у нас получилось 3 подгруппы: 


1. "Индекс введен?" 

2. "Индекс действующий?" (существует ли адрес с таким ин- 
дексом в Российской Федерации?) 

3. "Значения индекса". 


Каждый из элементов имеет свой уникальный /0, например, эле- 
мент, когда пользователь вводит в поле индекса 6 цифр, мы обозна- 
чили как Индекс эл 005 (элемент номер 005 страницы с индексом). 


Буквенная часть Ш (Индекс эл) — это вещь произвольная. Про- 


сто мне кажется, что для разбираемого примера это название 
интуитивно и логично. 


Прошу заметить, что мы набросали элементы как позитивных, 
так и негативных сценариев. 


Нигилистический настрой и практическая методология 181 


Этап 2. Комбинация элементов (табл. 2) 


Теперь мы начинаем комбинировать элементы между собой. 


Таблица 2 


Комбинация элементов 


ре Г 
щего российского индекса: 119602 
Еос а В ВИЕЙ 


Индекс эл 001 
Индекс эл 002 
Индекс эл 003 
Индекс эл 004 
Индекс эл 005 
Индекс эл 006 
Индекс эл 007 
Индекс эл 008 


индекс недействителен, 5 цифр: 11960 Г || 


индекс недействителен, 7 цифр: 1196021 


индекс недействителен, буквы: 119602 
(буква "о" вместо нуля) 


индекс недействителен, специальные 
символы: 11(602 


(символ "(" вместо девятки) 

индекс недействителен, пробел 

между цифрами: 1196 02 
ПН С И В 


Как видно, мы скомбинировали элементы табл. 1 в сценарии. 
У каждого из сценариев есть свой уникальный /1), например сце- 
нарий, когда в поле индекса не вводится никакого значения, про- 


ходит под штампом Индекс ком 008 (комбинация номер 008 стра- 
ницы с индексом). 


Кстати, обратите внимание: 


в данном конкретном примере мы играем с частью сценария под 
названием "данные"(варианты индекса), 

сначала расписываем позитивные, а затем негативные сценарии, 
сценарий Индекском 008 не был комбинацией элементов табл. 1, 
а напрямую следовал из элемента Индекс эл 002. 
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Вопрос: зачем мы присваивали уникальный //) каждому из эле- 
ментов в табл. 1, если мы их не используем? Ответ: иногда в 
табл. 2 вписывается не содержание элементов (как мы это 
сделали), а 12. Кроме того, если у элемента есть /), то это просто 
удобно для ссылки. 


Например 
• при обсуждении, когда у вас и вашего коллеги есть по экземпляру 
табл. 1 или 


• когда я рассказываю вам о матричном методе. 


Итак, у нас есть 8 сценариев для страницы, когда пользователь 
должен ввести некое значение (либо пустое место) для индекса 
места жительства. Мы можем сразу же, используя эти сценарии, 
написать тест-кейсы. Ожидаемым результатом для всех, кроме 
Индекс ком_001, будет перезагрузка страницы с индексом с со- 
общением об ошибке: 


"Введите действительный российский индекс". При этом текст 
"Индекс места жительства*" будет красного цвета. 


Для ИндекскомОО 1 ожидаемым результатом будет следующая 
страница: 


Имя*: | 
==; ==> 


Фамилия : | | 


| 
Е-майл”: | | 


Пароль; 


Подтверждение : 
пароля“: | | 
Зарегистрироваться | 


* поле обязательно для заполнения 


Теперь вспомним об этапах покупки книг: 


а. Регистрация (если нет счета пользователя). 

б. Заполнение книгами виртуальной корзины. 

в. Редактирование корзины: какие-то книги может убрать, 
каких-то купить больше, чем одну. 
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г. Указание деталей доставки. 
д. Оплата. 


Так вот мы придумали сценарии только для первой части нашей 
версии регистрации (вторая часть — это страница с именем, фа- 
милией, е-мейлом, паролем и подтверждением пароля). У второй 
части тоже будут свои табл. 1 и табл. 2. 


Более того, у каждого из остальных этапов тоже могут быть 
свои одна или более связок табл. 1 — табл. 2. 


Черноящичное тестирование веб-проекта — это манипуляции 
с одной или больше веб-страниц, зависимых друг от друга, 
определенная комбинация которых ведет нас к определенному 
ожидаемому результату. 


Таким образом, иногда появляется потребность 


. в табл. 97 когда сценарии из табл. 2 становятся элементами 
более сложных сценариев, 

. в табл. 4, когда сценарии из табл. 3 становятся элементами 
еще более сложных сценариев, 

• ит.д. 


Кстати, 


иногда в табл. 1 мы сразу отражаем возможные значения для несколь- 
ких связанных между собой веб-страниц. 


Я знаю, что матричный метод в начале работы по нему кажется 
сложным и запутанным. Единственный способ освоить его — это 
использовать на практике, что мы с вами сейчас и сделаем. 


Однажды в классе по "юниксу" на занятии по теме "Регулярные 
выражения" (наука поиска паттернов в тексте) один товарищ 
удивительно метко выразил физическое состояние всех студен- 
тов: "Это как операция на головном мозге". Я не удивлюсь, если 
в начале использования матричного метода у вас будет схожее 
состояние. 


Итак, предлагаю вам сейчас самостоятельно создать табл. | и 
табл. 2 для второй части регистрации. Также прошу вас написать 
тест-кейсы по полной форме на каждый из сценариев первой и 
второй частей регистрации. 


Далее. 
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Одна из прелестей матричного подхода заключается в наглядно- 
сти — мы видим перед собой таблицу со структурированными 
вариантами сценариев, и нам удобно комбинировать их в более 
сложные сценарии или непосредственно переносить их в тест- 
кейсы. 


Кстати, во многих случаях нет смысла идти дальше табл. 1, например 
когда сценарии для тест-кейсов непосредственно вытекают из эле- 
ментов табл. 1 или когда сценарии для тест-кейсов можно просто до- 
мыслить, скомбинировав в уме элементы табл. 1. 


3. БЛОК-СХЕМЫ 


В беседе о продюсерах и вещах, которые им нужно улучшить в 
своей работе, мы уже говорили о блок-схемах. Блок-схема — это 
графическая презентация некого процесса. 


Блок-схемы допускают разные уровни абстракции, например 
процесс регистрации можно представить и в таком виде: 


Процесс регистрации 


Страница (1) 
“Регистрация” 


Заполнение и ввод 
страницы (1) 


Заполнение и ввод 
страницы (2) 


Страница (3) 
“Подтверждение 
регистрации” 


Эта блок-схема и ее сестра из беседы о цикле разработки ПО 


• похожи тем, что демонстрируют нам логику работы реги- 
страции и 

• различаются тем, что имеют различную детализацию этой 
ЛОГИКИ. 
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В своей работе тестировщики используют ту степень детали- 
зации, которая нужна для конкретной ситуации: если мы тес- 
тируем саму регистрацию, то нам необходима большая степень 
детализации (процесса регистрации) по сравнению с ситуацией, 
когда нам нужно увидеть место регистрации как часть процесса 
покупки. 


Идея о разных степенях абстрагированности раскладки в зави- 
симости от того, ЧТО и КАК мы тестируем, напрямую отно- 
сится и к черновику-чистовику, и кматричному методу. 


Вот элементарные, непробиваемые и вечные формы (блоки) для 
составления блок-схем, которых вам будет достаточно в боль- 
шинстве ситуаций: 


Точка начала/конца блок-схемы может 
"Регистрация" содержать название этой точки (например, 
название веб-страницы) или просто и со 
вкусом величаться "Начало"/"Конец". 


Заполнение и ввод Это любой этап процесса, кроме этапов 
страницы (1) начало/конец, решение или перенос. 


Решение — некая точка, после которой 
возможны, как правило, два варианта раз- 
вития процесса. 


Страница (1) 


Индекс 
легитимен? 


Перенос ставится в том случае, если данное 
ответвление процесса представлено (будет 
представлено) другой блок-схемой. 


Смотри 
блок-схему 
покупки 


Вот несколько рекомендаций по составлению блок-схем. 


1. Перед составлением блок-схемы назовите основной про- 
цесс, описываемый ею, например "Процесс регистрации". 

2. Сначала набросайте путь основного течения процесса, на- 

пример, в случае с регистрацией это три блока, показанные 

на последней блок-схеме (страница 1, страница 2 и под- 

тверждение). 

Называйте каждый блок кратко и информативно. 

4. Приводите ссылки на полезную информацию, например, 
см. Спек #9017 — это ссылка на соответствующий спек. 


ә 
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„Страница (1) см. Спек #9017 
Регистрация 


5. Для наглядности презентации старайтесь скомпоновать 
блок-схему таким образом, чтобы процесс шел сверху вниз 
и слева направо. 

6. Для превентирования ошибки в толковании избегайте пе- 
ресечения стрелок. 

7. Протестируйте (проверьте) законченную блок-схему на пред- 
мет соответствия спеку или другому источнику. 


Для тренировки нарисуйте блок-схему следующей ситуации. 
Идея: вскипятить чайник. 


Вот вам в помощь блоки решений, которые предстоит разложить 
в блок-схеме: 


1. Вода в чайнике есть/нет. 
2. Плита включена да/нет. 
3. Чайник кипит да/нет. 


Для совершенствования в составлении блок-схем очень рекомен- 
дую найти ресурсы в Интернет е или купить книгу. 


Блок-схемы — это визуальные источники идей для тестиро- 
вания. Кроме того, 


как и в случае со всеми методами генерации тестов, процесс 
создания блок-схем вызывает рождение множества превосход- 
ных идей для тестирования, открывает тестировщику новые 
грани ПО и вызывает ряд вопросов, которые не возникли бы 
при простом прочтении спека. 


Политический момент 
как известно, 


теория (простое прочтение спека перед его утверждением) и 
практика (работа со спеком при создании тест-кейсов) — это две 
разные вещи. 


На "практике", если спек более или менее сложный, неизбежно воз- 
никнет необходимость в уточнениях. 
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Знайте, что отвечать на вопросы по спеку — это святая обязан- 
ность продюсера. 


Вы имеете право, нет, ОБЯЗАНЫ задать ему ВСЕ вопросы по спеку, ко- 
торые у вас возникнут, ибо шкуру будут спускать с вас, а нес него, если 
вы из-за неотвеченных вопросов пропустите баги. 


Кстати, обязательно сохраняйте всю переписку в отдельном фолдере 
(папке) е-мейл клиента (дайте фолдеру наименование (Ю) спека): 
вдруг продюсер дал вам уточнение, оно было неверным, вы написали 
тест-кейс с ошибкой/не написали тест-кейс вовсе и пропустили серь- 
езный баг? 


Нет е-мейла — нет доказательств, есть е-мейл — есть доказательства. 


Если уточнение по спеку было сделано устно, пошлите е-мейл продю- 
серу, где опишите то, как вы поняли уточнение, и спросите "Я правиль- 
но понял?". 


Если продюсер не отвечает, пошлите ему тот же е-мейл из фолдера е- 
мейл клиента "Отправленная почта" чтобы он видел, что уже один 
раз проигнорировал ваш запрос. 


Если ответа снова нет и продюсер не болен, не уехал на ПМЖ в Австра- 
лию, а даже очень здоров, строит дачку в Малаховке, и вы видите его в 
столовой каждый день, то просто перешлите последний из е-мейлов 
продюсера своему менеджеру и сообщите ему, что не можете рабо- 
тать по спеку. 


Менеджер не будет сам говорить с ним, а переправит ваш е-мейл ме- 
неджеру продюсеров, чтобы тот спросил у продюсера: "В чем, собст- 
венно, дело?" Даю гарантию, через час продюсер сам прилетит к вам, 
какни в чем не бывало хлопнет по плечу, как лучшего друга, и проведет 
с вами столько времени, сколько нужно, травя байки и находя удачные 
аналогии для того, чтобы вы лучше поняли материал. "Бизнес есть 
бизнес", вы ищете баги и, чтобы быть эффективным, должны по- 
лучить есю информацию по спеку. 


Теперь суперважная вещь в отношении методов генерирования и 
отбора тестов. 


Превосходные результаты дает комбинирование методов. 


Например, можно набросать черновик и в качестве чистовика создать 
табл. 1, сгруппировав в ней идеи из черновика. 

С другой стороны, имея табл. 1, табл. 2 ит.д, можно использовать метод 
черновик-чистовик, чтобы выделить сценарии из элементов табл. 1, 
табл. 2 и т.д. 

С третьей стороны, можно создать блок-схему, чтобы нагляднее ви- 
деть процессы, описанные в таблицах, и найти новые интересные 
идеи. 


В общем бесчисленное множество комбинаций и огромное поле для 
творчества! Как мы уже говорили, в тестировании НЕТ ДОГМ 
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и даже сами основы отрасли знания "Тестирование" постоянно 
находятся под обстрелом, так что дерзайте и находите именно те 
приемы и методы, которые будут работать для вас в тех ситуа- 
циях, в которых вы будете работать. 


Методы отбора тестов 


1. Оценка риска (715К еѕйітаіе). 
2. Эквивалентные классы (еўиіуаіепі сіаѕѕеѕ). 
3. Пограничные значения (Роипӣагу уаіиезѕ). 


Общая вещь: методы отбора тестов применяются во время 
или после генерирования тестов. 


1. ОЦЕНКА РИСКА (715% езйтее) 


Представьте, что вы только что прикупили отель где-нибудь в 
горах Сьерра-Невада в Северной Калифорнии. У вас нет опыта 
работы менеджером отеля, но вы чувствуете себя абсолютно уве- 
ренным в своей новой роли, так как у вас есть высшее образова- 
ние в области физики твердого тела и такую фигню, как управле- 
ние отелем, вы, конечно, осилите на раз. 


К вашему отелю ведут три дороги: 


• первая соединяет отель и ответвление скоростной магист- 
рали, 

• вторая соединяет отель и дорогу, ведущую к горнолыж- 
ным курортам, 

• третья соединяет отель и небольшую проселочную дорогу. 
по которой ездят в основном местные жители. 


Всетри дороги имеют одинаковую протяженность. 
10 человек уже приехали и 30 человек должны приехать сегодня. 


Всю ночь шел снег, и все три дороги замело так, что ни один 
джип не проедет ни по одной ИЗ НИХ. 


У вас есть только одна снегоуборочная машина, и на уборку лю- 
бой из дорог уйдет полдня. Так что нужно выбирать, с какой из 
них начать. 


Можно подойти к решению этой задачи чисто субъективно. 
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Абсолютно очевидно, что по дороге номер 3 могут приехать 
только ваши местные кореша 


• для игры в покер (но сегодня не день покера — пятница) 
или 
на барбекю (но сегодня не суббота). 


Значит, дорога 3 остается в снегу. 


Абсолютно очевидно, что дорога номер 2 также не является 
приоритетной в расчистке, так как абсолютно очевидно, что 10 
меньше 30. 


Таким образом, наш план: 


• посадить отельского "жнеца, швеца и на дуде игреца" за 
руль снегоуборочной машины расчищать роад намбер уан: 
дорогу к скоростной магистрали; 

• вывесить в лобби отеля большой плакат "Дорог на гор за- 
крыт. Не ходи, а то хана" для уже вселившихся; 

• накормить уже вселившихся бесплатным завтраком (в каче- 
стве извинения). 


Запомним, с какой уверенностью мы говорили себе: "Абсолютно 
очевидно". 


Давайте перед тем как реализовывать наш гениальный план, ос- 
нованный на очевидных вещах, остановимся на минутку у стойки 
регистрации и поговорим с менеджером отеля, который прорабо- 
тал в нем 20 лет. 


Первый вариант разговора 


Вопрос: "Что делать, Джеймс?" 

Ответ: "Босс, все очень просто. Все, кто уже вселился в отель, 
приехали играть в снежки, кататься на беговых лыжах или просто 
дышать свежим воздухом. Я это знаю потому, что переговорил с 
каждым из них и знаю большинство из них, так как они приезжают 
каждый год. Поэтому нет никакого смысла в расчистке дороги 
номер 2, все остаются в отеле или развлекаются в его окрестностях. 


Я также знаю, что 16 человек из 30 — это компания, которая вы- 
едет к нам рано утром из Рино (я вчера говорил по телефону с 
одним из них) по этой дороге (показывает на карте), которая пе- 
ресекается с дорогой номер 3. Соответственно они прибудут к 
нам по дороге номер 3. 
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Далее, посмотрите на монитор. Где живут 12 из 14 оставшихся 
клиентов? Они все живут в Сан-Франциско и окрестностях. 
Только что передали по радио, что на единственной скоростной 
дороге, ведущей из Сан-Франциско, из-за снегопада уже образо- 
вались страшные пробки. Кроме того, скорее всего большинство 
членов сан-францисской команды поедут после работы, т.е. в 4 
часа, а значит, будут здесь не раньше 8. 


Следовательно, нам нужно сначала расчистить дорогу 3 и по- 
сле этого заняться дорогой 1. 


Кстати, остаются еще двое, едущие из Техаса. Вот их мобильный 
телефон. Я собираюсь им позвонить, рассказать о ситуации со 
снегом, наших планах по расчистке и скоординироваться с ними, 
как им лучше до нас добраться". 


Второй вариант разговора 


Вопрос: "Что делать, Джеймс?" 

Ответ: "Босс, надо сначала расчищать дорогу 2, ведущую к 
горнолыжным курортам. Все наши постояльцы — это горнолыж- 
ники. Кроме того, оставшиеся 30 человек скорее всего сначала 
заедут на курорт, покатаются там до вечера и вечером поедут к 
нам — не будут же они терять сегодняшний день, я сам заказывал 
им пропуска со скидкой на подъемники, а пропуска начинают 
действовать сегодня". 


Третий вариант разговора 


Вопрос: "Что делать, Джеймс?" 

Ответ: "Босс, нет проблем. Нам нужно расчистить и дорогу 1, и 
дорогу 2. Я не знаю, что важнее. Но знаю номер телефона моего 
приятеля — владельца снегоочистительной компании, он даст 
нам хорошую цену, и двумя машинами мы сможем к полудню 
расчистить обе дороги. Ну, потратим немного денег, зато сохра- 
ним репутацию отеля, ставящего заботу о клиенте выше всего". 


Мораль: 


субъективные суждения, основанные на тупосамонадеянном 
"Абсолютно очевидно", могут элементарно завести нас в си- 
туацию, когда ресурсы потрачены впустую, так как не учи- 
тывают реальности. В то же время выводы, сделанные исходя 
из достоверной информации, ведут к эффективным решениям 
даже при нехватке ресурсов. 
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То, что сделал для нас мистер Джеймс, было оценкой риска. Он 
смог сделать оценку риска, так как 


. владел информацией и 


знал, как этой информацией распорядиться. 
Обратно к тестированию ПО. 


Наша задача — это 


• получить информацию, 
• если возможно, узнать мнение человека, владеющего во- 
просом, и 


оценить риск по каждой ИЗ функциональностей, которые 
предстоит протестировать. 


Людьми, которые владеют вопросом, могут быть продюсер, глав- 
ный бухгалтер, финансовый директор, бизнес-аналитик. Информа- 
цию можно получить также из статистики или других источников. 


Поверьте, что такой подход даст удивительные результаты. 


Допустим, у нас есть небольшой проектик, где нужно протести- 
ровать новый (переписанный и оптимизированный) код для уже 
давно существующих функциональностей: 


а) сделки купли-продажи между пользователями внутри Аме 
рики; 

б) сделки купли-продажи между пользователями в Японии; 

в) сделки купли-продажи между пользователями в Японии 


и США. 
Разложим эти функциональности: 
Таблица 1 
— я со ч 
о о о о 
И || 
Я Я Я Я 
а е М 
я я я я 
о о о о 
Е" Е" Е" Е" 
|" |" |" |" 
> > > > 
Продавец 
Американец Е 
Японец х 
Покупатель 
Американец х 
Японец х 
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Таблица 2 


Индекс эл 001 
Индекс эл 002 
Индекс эл 003 
Индекс эл 004 


Помните, я говорил, что применение методов генерирования тес- 
тов дает вам более глубокое понимание спека? Вот и теперь, де- 
лая матричную раскладку, мы увидели, что на самом деле у нас 
не три, а четыре направления для тестирования. Разложим их на 
блок-схеме. 


Блок-схема по спеку #1123 


Постановка мозгов 


Есть превосходный профессиональный термин Йом (течение, процесс) 
(будем использовать его в транслите как "флоу"). Флоу — это один или 
больше сценариев использования или работы ПО. Например, у нас есть 
флоу Американец -> Американец. В данном конкретном случае на это флоу 
можно написать множество сценариев (например, с разными суммами 
оплаты, транзакции между разными штатами и т.д.). 


Итак, у нас есть четыре флоу. 


Давайте снова поиграем в "Абсолютно очевидно" и решим во- 
прос о приоритетности каждого флоу. Допустим, что покупаются 
и продаются запчасти для автомобилей: 
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а. Скорее всего, самым приоритетным будет флоу Япо 
нец —> Американец, так как в США очень много японских 
автомобилей, запасные части производятся в Японии и 
наш сайт — это очень важный канал для поставок. 

б. Ниже идет флоу Американец —> Американец, хотя внут 
ренний рынок американских запчастей очень велик, но есть 
много других каналов поставок кроме нашего веб-сайта. 

в. Далее идет Американец —> Японец, это флоу менее при 
оритетное, чем о и б, но более приоритетное, чем г. 

г. Самый нижний приоритет у флоу Японец —» Японец, так 
как в Японии развита инфраструктура купли-продажи зап 
частей и нашим сайтом там почти не пользуются. 


Вроде бы все смотрится логично, но до тех пор, пока мы не нач- 
нем копать. 


Вопрос: Откуда у меня информация, на основании которой я сде- 
лал свои выводы? Откуда я знаю, что, например, в случае а (Япо- 
нец —» Американец) "наш сайт — это очень важный канал для 
поставок"? 

Ответ: Я знаю это, так как где-то (может быть, краешком уха) 
услышал или прочитал (может быть, в определенном контексте) 
эту информацию. 


А что, если я неправильно понял эту информацию или она, 
подобно постмодернизму, устарела? 


Далее. 


Вопрос: Что значит, что "внутренний рынок американских зап- 
частей очень велик"? Насколько он велик? Ответ: ... 


Карточным домиком были наши рассуждения. А ведь все ка- 
залось таким логичным... 


Давайте лучше пойдем к продюсеру, покажем ему нашу блок- 
схему и попросим совета. 


Пришли, показали, попросили. 


Продюсер делает пару звонков, и мы идем к бизнес-аналитику. 
Тот видит нашу блок-схему, поднимает данные по транзакциям 
за последние два года, и вот что мы имеем. 
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а. Самое большое количество сделок было между японскими 
пользователями (Японец —» Японец). Продюсер добавляет, 
что продвижение на японском рынке — это главный при 
оритет компании, как было сказано на очередном съезде, в 
смысле было сказано на последнем собрании. 

б. Вторым по приоритетности идет Американец —» Японец. 
Вот данные по сделкам. Продюсер добавляет, что недавно 
были заключены контракты с крупными американскими 
автозаводами о том, что те будут использовать наш веб-сайт 
для продаж за рубеж. 

в. Третьим будет Американец —> Американец, так как вот 
цифры. Продюсер добавляет, что конкурирующие сайты и 
другие каналы поставок завоевали местный рынок. 

г. Четвертым будет Японец —» Американец, так как вот циф 
ры. Продюсер добавляет, что японские компании распре 
деляют запасные части через своих авторизованных аме 
риканских дилеров, а американские дилеры японских ино 
марок используют наш сайт неохотно. 


Затем мы попросили дать процент для каждого флоу относитель- 
но общей суммы сделок по всем четырем флоу (это было немного 
больше, чем было нужно, так как я уже знал приоритетность ка- 
ждого флоу, но, как говорят, "кашу маслом не испортишь" и "куй 
железо, пока горячо"): 


Блок-схема по спеку #1123 


10% 37% 2% 51% 
пз п2 п4 п1 


= 


Теперь у нас есть данные, соответствующие реальности и осно- 
ванные 

• на информации из объективных источников и 

• на мнении компетентных лиц. 


У нас есть не просто приоритеты, а приоритеты, подкрепленные 
цифрами (проценты) и пониманием бизнеса (комментарии про- 
дюсера). 
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И еще мы снова видим, что эти превосходные, проверенные дан- 
ные снова абсолютно противоречат нашему, казалось бы, незыб- 
лемому, но на поверку очень даже "зыблемому" "Абсолютно 
очевидно". 


Что делать, если вдруг есть две функциональности с одинако- 
вым приоритетом? С чего начать? Начните с той, которая 6бо- 
лее сложная и трудоемкая. 


Последний вопрос в отношении оценки риска — это использова- 
ние полученной информации. Флоу с более высоким приорите- 
том (который мы отражаем в поле тест-кейса "Приоритет") тес- 
тируется 


. в первую очередь и 
• более тщательно. 


Кроме того, в дальнейшем у вас всегда будет аргумент, почему 
вы тестировали именно это и именно в таком объеме. И этим 
аргументом будут данные по оценке риска, которые вы использо- 
вали как профессионал-тестировщик, ориентированный на сча- 
стье пользователя. 


2. ЭКВИВАЛЕНТНЫЕ КЛАССЫ (едиѓуа/епі сіаѕѕеѕ) 


Это суперполезная вещь, которой мы немедленно дадим опре- 
деление: 


эквивалентный класс — это одно или больше значений ввода, 
к которым ПО применяет одинаковую логику. 


Предположим, что наш книготорговый веб-сайт запускает новую 
кампанию "Больше тратишь — больше скидка". Вот табличка из 
спека. 


Потраченная сумма, Скидка, 

руб- % 
200 — 500 2 
5500—1000 3 
1000 — 5000 4 
5000 и более 5 


Мы, конечно, сразу увидели 3 бага спека: 
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Багі: 
Непонятно, по какой ставке рассчитывается скидка, если по- 
трачены следующие суммы: ровно 500 руб., ровно 1000 руб., 
ровно 5000 руб., так как каждая из этих сумм находится не в 
одной, а в двух корзинах со скидками. 


Баг 2: 


Что означает "Потраченная сумма"? Это количество дензна- 
ков, выплаченных только за книги, или полная сумма к оплате, 
включая оплату книг и расходы на доставку? 


Баг 3: 


Для полноты картины нужно дописать эквивалентный класс 
от 0 до 199,99, на значения которого никакая скидка не рас- 
пространяется. 


Что делаем? 


Правильно: идем к продюсеру. Извещаем о баге программиста. 
"Размораживаем" спек. Вносим в него изменения. 


Вот перед нами уже отредактированная табличка: 


Стоимость Скидка, % 
купленных книг, руб. 


2 
1000,00 — 4999,99 4 
5000,00 и более ШИЕ 


У нас получилось 5 эквивалентных классов: 


500,00 — 999,99 3 
5 


1000,00 — 4999,99 
5000,00 и более 
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Каждое значение внутри каждого класса является эквивалентным 
всем другим значениям этого класса. 

Почему? Потому что ко всем значениям класса должна приме- 
няться одинаковая логика кода. Например, при стоимости куп- 
ленных книг и 1215,11 руб., и 1745,45 руб., и 2000 руб. (класс 4) 
полагается скидка 4%. 


Составными частями класса являются: 


1. Значение или корзина значений ввода (например, от 500,00 
до 999,99) и 

2. Логика для вывода, т.е. ожидаемого результата (скидка 3% 
в случае с классом 3). 


Польза раскладывания значений ввода на эквивалентные клас- 
сы состоит в том, что мы отсеиваем огромное количество 
значений ввода, использовать которые для тестирования про- 
сто бессмысленно. 


Отсев происходит путем применения знаний о тестировании по- 
граничных значений. 


3. ПОГРАНИЧНЫЕ ЗНАЧЕНИЯ (Фоипаагу уаіиеѕ) 


Все очень просто. Давайте представим себе наши эквивалентные 
классы из предыдущего примера: 


0 200,00 500,00 1000.00 5000,00 


|. [ 


199.99 499.39 999,99 4999,99 


Вертикальная пунктирная линия — это первое возможное значе- 
ние класса (нижний предел). 

Вертикальная сплошная линия — это последнее возможное зна- 
чение класса (верхний предел). 
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Пограничные значения — это конкретные предельные зна- 
чения, образующие водораздел между эквивалентными клас- 
сами. 


Для каждого эквивалентного класса может быть лишь один 
из трех вариантов: 


а. Есть только нижний предел (класс 5). 

б. Есть нижний и верхний пределы (класс 2, класс 3, класс 4). 

в. Есть только верхний предел (не рассматриваемый в данном 
примере класс, который ограничен только сверху гипотети 
ческим отрицательным значением, непосредственно пред 
шествующим классу 1). 


Пограничным тестированием (Боипдагу 1езИп®) называется 
применение метода тестирования пограничных значений. 


Вот полная версия метода тестирования пограничных значений. 


а. Сначала тестируется нижний предел данного класса (если 
он имеется). 

б. Затем тестируется верхний предел данного класса (если он 
имеется). 

в. Затем тестируется любое значение внутри данного класса. 
г. Затем тестируется верхний предел класса, непосредственно 
предшествующего данному классу (если предшествую 

щий класс имеется). 

д. Затем тестируется нижний предел класса, непосредствен 
но следующего за данным классом (если следующий класс 
имеется). 


а, 6, в являются позитивными тестами, гид 
— негативными тестами. 


Давайте же возьмем и протестируем эквивалентный класс 2. Суть 
тестирования заключается в том, чтобы удостовериться, что для 
покупок от 200,00 до 499,99 руб. (включительно) будет дана 
скидка 2%. Опустим шаги сценариев и поговорим только о дан- 
ных для них. Следуем методике тестирования эквивалентного 
класса, нам нужно лишь пять вариантов данных: 


200,00; 
499,99; 
315,11; 
199,99; 
500,00. 


Нуров 
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Почему нам хватило только 5 сценариев, мы поговорим через 
минуту. 


А сейчас давайте посмотрим, сколько возможных вариантов 
только для позитивных тестов у нас потенциально есть для 
класса 2: 


30000 (по количеству копеек в 299,99 руб. плюс один слу- 
чай, когда потрачено 200,00 руб.). 


Наша методика позволила обойтись лишь 3 тестами (пози- 
тивные тесты: а, б, в), которыми мы по сути протестировали 
30 000 значений. По-моему, выглядит впечатляюще. 


Теперь о 5 сценариях, которых было достаточно для позитивного 
и негативного тестирования класса 2; 


Представим себе схематично логику кода для решения вопроса о 
скидке для класса 25 


ЕСЛИ сумма > 200,00 И сумма < 499,99, 
ТО скидка = сумма /100 х 2. 


Теперь рассмотрим, как каждый из наших тест-кейсов точечно 
бьет по возможным проблемам кода. Прошу особого внимания — 
ничего сложного нет, но много нюансов. 


Тест-кейс Код с выделенной жирным шрифтом частью, 
которая проверяется данным тестом 


Возможная проблема кода, разоблачаемая тестом, и 
пример проблемы 


Ожидаемый результат 


а. Сначала тестируется [ЕСЛИ сумма > 200,00 И сумма < 499,99, 
нижний предел данного 


класса (если нижний 
предел имеется): Ошибка в знаке равенства и/или сумме нижнего 
200 предела. 


ТО скидка = сумма/100 х 2 


Пример (знакравенства перед 200,00 пропущен): 
ЕСЛИ сумма > 200,00 И сумма < 499, 99, 
ТО скидка = сумма/100 х 2 


2% от 200 


200 


б. Затем тестируется 
верхний предел 
данного класса (если 
верхний предел 
имеется): 

499,99 


в. Затем тестируется 
любое значение 
внутри данного 
класса: 

315,11 


г. Затем тестируется 
верхний предел класса, 
непосредственно 
предшествующего 
данному классу 

(если предшествующий 
класс имеется): 

199,99 


д. Затем тестируется 
нижний предел класса, 
непосредственно 
следующего 

за данным классом 
(если следующий 
класс имеется): 

500,00 
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ЕСЛИ сумма > 200,00 И сумма < 499,99, 
ТО скидка = сумма/100 х 2 


Ошибка в знаке равенства и/или сумме верхнего 
предела. 

Пример (499,00 вместо 499,99): ЕСЛИ сумма > 
200,00 И суммо < 499,00, ТО скидка = сумма/100 


х2 

2% от 499,99 

ЕСЛИ сумма > 200,00 И сумма < 499,99, 
ТО скидка = сумма/100 х 2 


Ошибка в знаках больше (>) и меньше (<). Пример 
(больше вместо меньше и меньше вместо больше): 
ЕСЛИ сумма < 200,00 И сумма > 499,00: ТО скидка 
= сумма/100х 2 


2% от 315,11 
ЕСЛИ сумма > 200,00 И сумма < 499,99, 
ТО скидка = сумма/100 х 2 


Тонкий момент. Здесь мы проверяем две вещи: 

1. Наличие скачка от верхнего предела предьцущего 
класса к нижнему пределу нашего класса. 

Это делается для следующей ситуации. Допустим, 
программист напечатал 100,00 вместо 200,00: ЕСЛИ 
сумма > 100,00 И сумма < 499,99, 

ТО скидка = сумма/100 х 2. Если сделана такая 
ошибка, то она не будет обнаружена ни тестом а, ни 
тестом 6, ни тестом е. 

2. Логическое "И", так как если бы у нас было "ИЛИ": 
ЕСЛИ сумма > 200,00 ИЛИ сумма < 499,99, 

ТО скидка = сумма/100 х 2, то к данному классу 
принадлежало бы любое в принципе возможное 
значение 


Скидка не равна 2% от 199,99 
ЕСЛИ сумма > 200,00 И сумма < 499,99, 
ТО скидка = сумма/100 х 2 


1. Наличие скачка от верхнего предела нашего класса 
к нижнему пределу следующего за ним класса. Это 
делается для следующей ситуации. Допустим, 
программист напечатал 599,99 вместо 499,99: ЕСЛИ 
сумма > 200 И сумма < 599,99, ТО скидка = 
сумма/100 х 2 
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Если сделана такая ошибка, то она не будет 
обнаружена ни тестом а, ни тестом б, ни тестом в, 
ни тестом г. 

2. Проверяется логическое "И", так как если бы у 
нас было "ИЛИ": 

ЕСЛИ сумма > 200,00 ИЛИ сумма < 499,99, 


ТО скидка = сумма/100 х 2, то к данному 
классу принадлежало бы любое в принципе 
возможное значение 


ПИ Скидка не равна 2% от 500,00 


Замечу, ЧТО ДЛЯ удобства в понимании мы производили тестиро- 
вание класса 2 изолированно от его собратьев. 


И теперь, поняв и разобравшись, давайте рассмотрим, как нам про- 
тестировать все эквивалентные классы данного спека: 


ставка скидки, % 
Класс 1 
| 199,99 | 99 
Класс 2 2 
117 | 11 
Еа 99 
3 


Класс 3 кона 00 


Го | 99 


Класс 4 4 
| 3265,26 | ‚26 
ЕЕ Е 
Класс 5 | 5000,00 | 00 5 


Итого 14 тест-кейсов для тестирования всех возможных значе- 
ний. Неплохо. Очень даже неплохо! 


На сером фоне 5 значений ввода, которые мы использовачи для 
изолированного тестирования нашего любимого кяасса 2. Прошу 
отметить следующую вещь: теперь, когда мы тестируем класс 2 
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вместе с окружающими его собратьями, для класса 2 доста- 
точно 3 тест-кейсов, так как случаи г. (199,99) и д. (500,00) 
покрываются при тестировании класса 1 и класса 3 соответ- 
ственно. 


Мы рассмотрели самый сложный вариант пограничного тестиро- 
вания, когда мы проверяли эквивалентные классы, включающие 
множества значений. Зато теперь, пройдя огонь, воду и медные 
трубы, нам ничего не стоит разобраться в более простом случае, 
когда эквивалентный класс содержит только одно значение. 


Пример 

Возьмем индекс, который должен быть равен 6 цифрам (Индекс_эл 005 из 
табл. 1, матричной раскладки поля "Индекс"). Применяем метод 
тестирования пограничных значений: 


а. 6 


г 5 
Д. 7 
Таким образом, у нас есть: 


• один позитивный тест 6 и 
• два негативных теста 5 и 7. 


Мы применяем метод 


• как обособленно (тестирование скидок), 
так и 


• в сочетании с другими методами генерирования и отбора 
тестов (использование пограничных значений на матрич 
ной раскладке поля "Индекс"). 


Идея о возможности обособленного или интегрированного 
применения, конечно, относится к каждому из методов гене- 
рирования и отбора тестов. 


Это все о пограничном тестировании. 


Важная мысль перед списком изученных нами вещей о подготовке 
к тестированию: 


Не методы должны управлять вашей подготовкой, а вы должны 
управлять методами так, чтобы с их помощью создать именно 
те тест-кейсы, которые с высокой вероятностью могли бы 
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найти баги. Для этого нужно в совершенстве владеть каждым 
из методов. И только практика может отточить ваши навыки. 
Практикуйтесь и помните о примере с шахматами, которым 
мы поставили себе мозги в начале нашей сегодняшней беседы. 


Сегодня мы узнали и изучили: 


Краткое подведение итогов 


1. Хороший тестировщик — это не просто некий работник компании, 
который может порвать код на части своими прикладными 
знаниями по тестированию. Хороший тестировщик — это неис- 
правимый циник, нигилист и Фома неверующий — все в отно- 
шении кода. 

Код — это убежище багов. 

Суть тестирования заключается в поиске багов. 

В отношении методов генерирования тестов: 


ом 


• при использовании метода Черновик-чистовик: Черновик — 
это полет мысли и вдохновения, "мозговой штурм", не огра- 
ниченный суетными приличиями бренного света. Чистовик — 
это подчищенный, причесанный и классифицированный Чер- 
Новик; 

• матричная раскладка может быть лишь простой классифика- 
цией элементов на табл. 1, а может и бесконечно углубляться 
в дебри комбинаций и комбинаций. Главное помнить, что 
матричная раскладка создается для тестирования, а не тес- 
тирование было придумано для матричной раскладки; 

• блок-схемы — это дочери добродетели под именем "Нагляд- 
ность". 


5. В отношении методов отбора тестов: 
оценка риска основывается на том, что мы пытаемся влезть в 
шкуру наших пользователей и бросить наши ограниченные ре- 
сурсы не на бессмысленное кликанье правыми, левыми и даже 
средними кнопками наших ошалевших мышек, а на тестирование 
вещей, реально приоритетных для пользователей. 


6. Методы генерирования тестов и методы отбора тестов — 
это ящик с инструментом. Под каждую задачу используется 
свой (свои) инструмент (-ты). 


Вопросы для самопроверки 


1. Какой настрой должен быть у тестировщика? 

2. Что такое код? 

3. Что такое тестирование? 

4. Какие вы знаете методы генерирования тестов? 
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Какие вы знаете методы отбора тестов? 

В чем суть метода Черновик-чистовик? 

Есть ли ограничение на количество таблиц в матричной рас- 
кладке? 

Каково основное преимущество блок-схем? 

Кто может помочь тестировщику в оценке риска? 


. Какая практическая польза от приоритезации при оценке риска? 


Приведите 5 правил тестирования пограничных значений. Какие 
из них позитивные, а какие — негативные? 


. Что нам дает комбинирование методов? 


ИСПОЛНЕНИЕ ТЕСТИРОВАНИЯ 


ЖИЗНЬ ЗАМЕЧАТЕЛЬНЫХ 
БАГОВ 


• ЧТО ТАКОЕ СИСТЕМА ТРЭКИНГА БАГОВ 
• АТРИБУТЫ БАГА 
• ПРОЦЕССТРЭКИНГА БАГОВ 


ак мы знаем, цель исполнения тестирования — поиск багов. 
Но на самом деле найти баг — это только часть работы (хотя 
и самая сложная). После того как баг обнаружен, 


• нужно занести его в систему трэкинга багов и 
• после того как он зафиксирован: 


а) проверить, на самом ли деле он был зафиксирован и 
б) не повредила ли починка этого бага другие части на 
шего ПО. 


Кстати, как мы помним, а и б называются регрессивным тес- 
тированием. 


Процесс, который начинается с занесения бага в систему трэкин- 
га багов (Вис Тғаскіпе $уѕіет), называется процессом трэкинга 
багов (Вис Тғаскіпе Ргосейиге), и для удобства понимания всей 
стадии исполнения тестирования мы начнем именно с него. 


Что такое система трэкинга багов 


Важная оговорка: нет двух интернет-компаний, у которых про- 
цесс трэкинга багов и все нюансы системы трэкинга багов были 
бы идентичны. Каждый, как известно, извращается как хочет. 
Моя цель — развить ваше понимание предмета так, чтобы 
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вы со спокойной улыбкой мастера смогли адаптировать полу- 
ченные знания к любым процессам и системам, которые встре- 
тятся вам на пути. 


Забудем о тестировании ПО. 


Допустим, мы совершаем тест-драйв на автомобиле, который со- 
бираемся купить. Проверяем ускорение, вхождение в поворот, 
удобство панели управления и сотню других важных вещей. По- 
сле этого садимся за стол и записываем вещи, которые обманули 
ожидания (т.е. баги), на пронумерованные страницы новой тетради 
в клеточку. Один баг на одну страницу. 


Например 


на странице под номером 1 пишем: "Неудобно пользоваться навигаци- 
онной системой"; 

на странице под номером 2 пишем: "Задержка в ускорении после на- 
жатия на педаль акселератора"; на странице под номером З пишем: 
"Слишком маленький багажник". 


Наша ни в чем не повинная тетрадь на самом деле является не 
только выброшенными на ветер деньгами, но и простейшей вер- 
сией того, что называется системой трэкинга багов (СТБ). 


Вспомним о тестировании. Опять же на примитивном уровне СТБ 
может представлять собой простой текстовый файл с записями о 
багах, который лежит на интранете и доступен участникам цикла 
разработки ПО. 


Итак, концептуально СТБ — это инфраструктура, позволяющая 


• создавать, 
• хранить, 

• просматривать и 
• модифицировать 


информацин о багах. 


Существует множество профессиональных СТБ — от бесплатной 
Багзиллы (Виэ2Ша) до многотысячедолларового тест-директора (Тез 
ГПіғесіог Бу Ѕевие), и естественно, что интернет-компании исполь- 
зуют для трэкинга багов не тетрадки или текстовые файлы, а именно 
специальное ПО, непосредственно созданное для трэкинга багов. 
О таком ПО и процессе трэкинга багов мы и поговорим сегодня. 


Каждый баг, занесенный в СТБ, представляет собой вирту- 
альную учетную карточку 
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Каждая такая карточка существует не сама по себе, а как часть 
процесса трэкинга багов (далее — Процесс). 


С каждым багом, занесенным в СТБ, начинается новый Процесс. 


Вопрос: Как определить, на какой стадии Процесса находится 
каждая конкретная карточка? 

Ответ: Ничего нет проще — нужно просто посмотреть на ее ат- 
рибуты. 


Пример 
Одним из атрибутов является статус бага. Статус может принимать 
одно из трех значений: 


* Ореп(откыт) 
• Сіоѕеа (закрыт) либо 
• Ке-ореп (повторно открыт). 


Пример Процесса 


После того как баг заносится в СТБ, его статус автоматически стано- 
вится "Ореп"; после того как баг зафиксирован и регрессивное тести- 
рование подтвердило успех починки, мы меняем статус на "СіІоѕеа!"; 
если же тот же баг, после того как мы его закрыли, был найден снова, 
то мы меняем "Сіоѕеа" на "Ве-Ореп". 


Важно понять, что Процесе как формальный свод правил перви- 
чен и такой зверь, как СТБ, приобретается именно как инстру- 
мент для материализации Процесса. 


Другими словами, после инсталляции ответственный товарищ 
настраивает СТБ в соответствии с процессом, выбранным компа- 
нией, а не наоборот. 


В примере со статусом мы взглянули на процесс с высоты птичь- 
его полета. Опустимся же на землю и увидим все подробности. 


Допустим, мы нашли баг. Сам факт нахождения бага, даже если 
это критический дефект, не имеет никакого значения и веса, пока 
вы не сообщили об этом баге. Два вопроса: 


Кому сообщить? 
Как сообщить? 


Кому? Программисту, если это баг кода, либо продюсеру, если 
это баг спека. 


Как? Здесь есть много путей: можно позвонить, послать е-мейл, 
сказать пару ласковых при личной встрече и т.д. 
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Стандартный путь, принятый в софтверных компаниях, — это занести 
баг в СТБ. 


Таким образом, одной из основных функций СТБ является обес- 
печение коммуникации между участниками Процесса. 


Как фактически происходит занесение бага в СТБ? Например, так: вы 


• открываете веб-браузер; 

• печатаете в нем ОГ вашей СТБ в локальной сети и нажимаете 
Епіег; 

• после того как загрузилась страница СТБ, вводите имя 
пользователя и пароль; 

• нажимаете на кнопку "№ и? Бис" (Новый баг); 

• на веб-форме "Новый баг" заполняете поля и выбираете 
значения; 

• нажимаете на кнопку "Зибти пеуу Бис" (Занести новый баг). 


Все очень просто. 


Кстати, отныне баг в зависимости от контекста будет иметь одно из 
следующих значений или оба значения: 


• баг как отклонение фактического результата от ожидаемого ре- 
зультата и/или 

• баг как созданная в СТБ виртуальная учетная карточка, являю- 
щаяся, по чьему-либо субъективному мнению, презентацией не- 
кой проблемы. 


В чем разница, спросите вы. Отвечаю: проблема, занесенная в СТБ, 
может и не являться багом, например господин, опрометчиво занес- 
ший баг в СТБ, неправильно понял спек. 


Это была ненавязчивая вводная часть, и настоящее веселье только 
начинается. 


Атрибуты бага 


ВОС МОМВЕК (НОМЕР БАГА) 


Каждому новому багу СТБ автоматически присваивает уникаль- 
ный, следующий по порядку номер. Например, подходите вы к 
программисту и спрашиваете: "Слушай, браза, как там 1232 по- 
живает?" 
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5ОИММАКУ (КРАТКОЕ ОПИСАНИЕ) 


Краткое описание — это максимально информативное и сжатое 
описание проблемы. 


Как правило, текстовое поле для краткого описания не превышает 
100 символов и в эти 100 символов (включая пробелы) нужно 
уместить информацию, достаточную для понимания сути проблемы. 


Кстати, 


то, как тестировщик формулирует краткое описание, наглядно говорит 
о его профессионализме. 


Пример самого плохого Зиттагу 


"Ничего не работает". За такое Зиттагу раньше били по голове канде- 
лябром, и хотя сейчас времена другие, но все равно, пожалуйста, ни- 
когда, никогда не пишите в кратком описании ничего подобного. 


Почему поле для краткого описания такое короткое? Потому что 
баги, занесенные в СТБ, выглядят примерно так, списком, на зна- 
чения которого можно кликнуть мышкой и получить полную ин- 
формацию по конкретным багам: 


Е 


| Неверное значение колонки гезий таблицы ее апѕасйоп для 7154 | значение колонки геѕи/і таблицы ее гапзасноп для ГИ5А 


ЕЕ 33 < Неверное значение баланса би’Исй после покупки 
Ошибка при логине: "801 Еггог" 
Корзина не сохраняет выбранные книги 


Если есть номер спека, то можно давать краткое описание в та- 
ком формате: 
<номер спека> : <само краткое описание», например: 

7422: неверное значение баланса 5иисй после покупки. 


Если баг начинается с номера спека, то баги 


• можно сортировать по колонке $иттату, таким образом баги, 
принадлежащие к одному спеку, будут кучковаться вместе, и 

• можно искать по номеру спека, используя функциональ- 
ность СТБ "Поиск". Очень, кстати, удобно и вам, и про- 
граммистам, и продюсерам. 
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Итак, в кратком описании сжато и информативно излагаем суть 
проблемы. 


ГРЕЅСКІРТІОМ АМР 5ТЕРУ ТО КЕРКОРОСЕ 
(ОПИСАНИЕ И ШАГИ ДЛЯ ВОСПРОИЗВЕДЕНИЯ ПРОБЛЕМЫ) 


Это многострочное текстовое поле. Я пользуюсь следующим 
форматом для заполнения этого атрибута: 


"Юеѕсгірбоп: 
Полезная информация о баге: описание, комментарии, нюансы и т.д. 


85іерѕ їо гергодисе: 
Конкретные шаги для воспроизведения проблемы. 


Вис: Фактический результат. 
Ехресіеа: Ожидаемый результат. 


Пример для бага 1 


"Реѕсгірііоп: 
При оплате картой МІЅА в колонке геѕиі# таблицы сс {гапзасйоп в базе 
данных записывается неверное значение. 


Используйте следующую информацию для воспроизведения проблемы: 


Эккаунт: іеѕіиѕег1/ра$%иОга 

Наименование товара: Боок117 

Данные карты: 

Номер: 9999-5148-2222-1277 

Окончание действия: 12/07 

СИ/2: 778 

5011: ѕеІесі гезий тот сс _ігапѕасііоп ићеге іа = <номер заказа>; 


Ѕіерѕ ќо гергодисе: 


Открой иим. таіп.іеѕіѕһор.гѕ 
Введи имя пользователя. 

Введи пароль. 

Нажми кнопку "Войти". 

Введи наименование товара в поле поиска. 
Нажми кнопку "Найти". 

. Кликни линк "Добавить в корзину". 
. Кликни линк "Корзина". 

. Кликни линк "Оплатить". 

10. Выбери вид карты. 

11. Введи номер карты. 

12. Введи срок окончания действия. 
13. Введи СИ/2. 

14. Нажми кнопку "Завершить заказ". 
15. Запиши номер заказа. 

16. Запроси базу данных с 8011. 


Вид: 20. Ехресќеа: 
10. 


оо моо мо м№ м 
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Важный момент: 


5іерѕ іо терғойисе могут использоваться для воспроизведения 
проблемы и программистами, и тестировщиками, и продюсе- 
рами. В тест-кейсах можно допустить употребление принятых в 
отделе качества сокращений и акронимов, а также ссылок к 
внешним документам: коллеги-тестировщики поймут и простят, 
но многие очевидные для тестировщика вещи совершенно не- 
очевидны, например, для продюсера. Поэтому, пожалуйста, пи- 
шите четкие и подробные шаги, чтобы ваши коллеги из других 
отделов без проблем воспроизводили баги и нахваливали ваши 
описания. 


Вот небольшой список наиболее часто встречающихся элемен- 
тов веб-страницы, который позволит вам более четко описывать 
и шаги для воспроизведения багов, и шаги тест-кейсов. 


Я текст. Вещь незаменимая 


Текст (іехі) 


Не знаю, какое описание дать здесь. Текст есть текст. 
Кстати: 


1. Текст может быть неверного содержания“ (противоречащий 
спеку): например, неверное сообщение об ошибке. 

2. Нужного текста может не быть вовсе“. 

3. Может быть неправильным шрифт (ои), цвет (соіог), размер 
(5ісе) текста. 


Естественно, что проблемы неверного содержания элемента или полного его 
отсутствия могут быть не только у текста, но и у всех остальных элементов. 


Я линк. Просто линк 


Линк (/ілҝ) 


Также известен как ссылка или гиперссылка. Если нажать на линк 
(или, по-простому, "кликнуть линк") (сДск Пий), то мы попадем 
• либо на другую веб-страницу, 


• либо на определенное место страницы, на которой находится 
линк (например, если на одной странице есть список названий 
глав книги (Содержание) и сами главы, то название каждой главы 
в Содержании может быть слинковано с началом текста главы). 
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Кстати: 


1. Линк может быть сломан (Бгокеп ПпЕ), т.е. нажимаем на линк 


и никуда не идем либо получаем сообщение, что страница не 
найдена. 

2. Линк может вести не туда , куда нужно (тіѕ/еаіпо Пт), напри- 
мер, вы кликаете на линк" Контактная информация", а попадаете 
на страницу "Корзина". 

Для проверки сломанных линков есть прекрасный бесплатный тул, 


называемый Хепи '5 [лик $1еиіћ (можете скачать его из Интернета). 


Картинка (їтасе) 


Ну, куда же мы без них. Картинки — это графические файлы (как 
правило, СІҒ либо ЈРС), на которые ссылается НТМГ-код, веб-стра- 
ницы и которые через Интернет летят на жесткий диск наших ком- 
пьютеров. Если вы в окне браузера видите картинку, то знайте, что 
она сохранена на жестком диске... 


Кстати: 

Сломанная картинка (Бгокеп йпазе): ситуация, когда, как правило, 
путь к графическому файлу в НТМГ-коде указан неверно или путь ука- 
зан верно, но сам файл поврежден (со’гирле/4атаееа) и на веб-стра- 
нице мы видим лишь рамку, в которой должна была быть картинка: 


5, 
в” 


Участник 
ВатЫег”5 


Слинкованная картинка (Дикей птазе) 


По сути это линк, который представлен не текстом, а картинкой. 
Соответственно У слинкованной картинки могут быть болезни как 
линков, так и картинок. 
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Я имя текстового поля: |А я текст внутри текстового поля 


Однострочное текстовое поле ((ехфох) 


Однострочное текстовое поле (или просто "текст-бокс") — это один 
из элементов веб-формы (иер /огт), которая может быть на веб-стра- 
нице. Для примера: веб-форма всегда является частью веб-страницы 
с регистрацией, когда вы вводите имя, пароль, е-мейл (и т.д.) и 
нажимаете кнопку "Зарегистрироваться". Все остальные элементы, 
перечисленные далее: 


• многострочное текстовое поле; 
• поле для пароля; 

• радиокнопка; 

• чекбокс; 

• кнопка, 


также являются элементами веб-формы. 


Кстати, 

текстовое поле используется для введения множества видов текстовой 
информации: от имени пользователя до ввода текста, увиденного на 
кепча (от англ. сарісћа, читается как кэпча). 


Веб-индустрия использует кепча (которое является динамически 
сгенерированной картинкой) для того, чтобы превентировать 
автоматические программы от использования веб-сайта. Идея в 
том, что человек может распознать символы, изображенные на 
кепча, а компьютер — нет. Вот пример кепча — страница регист- 
рации на Үаћоо!. На ней изображено (буквы латинские): рЗт4ак: 


Мегіѓу Үоиг Ведіѕїгаіоп 


| Моге іпіо „ 
*Епќег {һе соде ѕһомп: 


Тһіѕ һе!Ірѕ Үаһоо! ргемег{ аиќотаќеа гедіѕігайоп. 


В отношении проблем: 


Размер текст-бокса (МАХГЕМСТН), т.е. максимальное количество 
символов, которое можно ввести в текстовое поле, может быть 
больше или меньше, чем указано в спецификации. 


Проверка количества символов, которое может принять в себя тек- 
стовое поле, проводится в рамках тестирования интерфейса пользо- 
вателя (О1Теѕііпе). 
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Я имя многострочного текстового поля: 


А я текст внутри многострочного текстового поля. 


Такие вот дела. 


Многострочное текстовое поле (їехї ету агеа) 


используется для ввода информации, которая не умещается в одно- 
строчном текстовом поле. Например, для создания постинга на 
интернет-форумах под предмет сообщения (ѕиђјесі) отдается текст- 
бокс, а под само сообщение — многострочное текстовое поле. 


Кстати, 


прекрасным, истинно сероящичным тестом является проверка того, 
умещается ли наш ввод в соответствующую колонку базы данных. 
Под вводом в данном случае подразумеваются данные, введенные 
посредством текст-бокса или многострочного текстового поля. 


Пример 
При регистрации наш новый пользователь заполняет соответст- 
вующую веб-форму и нажимает на кнопку "Зарегистрироваться". 


Некий файл (например, написанный на языке Руіһоп и живущий на 
сервере с приложением) трансформирует эту форму в язык, понятный 
базе данных (язык называется $01 — Ѕігисіиғеа Оиегу Г апдиаде, 
произносится как "эс-кью-эл"), и создает новую строку (гесога) в 
таблице, называемой, например, ИЗЕК — АБОКЕЗ$ (адрес 
пользователя). 


Допустим, что при создании таблицы ИЗЕКАРОКЕ$$ программист 
ошибочно указал максимальный размер колонки АБОВЕ$$1 в 7 
символов (УАВСНАЕ (7)) вместо 37, положенных по спеку. Это при- 
ведет к тому, что при создании новой строки в УЗЕКАРОВЕ$$ дан- 
ные, включаемые в колонку АРОКЕ$$1, будут ограничены 7 симво- 
лами, а 8-й и прочие символы будут отсечены (ігипсаїіеа) (кстати, 
пробел — это тоже символ): 


И$ЕВ_АБОБЕ$$ 


раина 
Е 


РОВ СИ О СЛИ И СИ СВ 
БО О О Со В СОЗ СИ 
КО С О С И С ЕС 


Что делаем? Правильно, заносим баг, и, после того как баг зафик- 
сирован и проверен нами, адреса, хвосты которых были отсечены, уже 
выглядят так: 
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О5ЕВ_АБОБЕ$$ 


О БОСИБ ас О С С НЫ 
на раст ања рат 
пшана слани: са 


3 [2216 Вакег 5игее | ВаКег Ѕёгееё | Шопбоп | Кк №№ | 
= Вошеуага адн ниси ШИ 
де Сісһу 


Кстати, хорошей идеей для ввода при тестировании является описа- 
тельный ввод, например, в текст-бокс Адрес 1 (данные которого идут 
в АРОКЕ$$1) нужно было бы ввести не милую сердцу 82 Вошеуага ае 
Сіісһу, а строку 


"а запятая является 38-м символом, 11111111111" 
и затем проверить базу данных. 
Если АррвВЕ$5 1 содержит строку 

"а запятая является 38-м символом", — 


ни символом больше, ни символом меньше, то АРОКЕ$$ 1 вмещает 
ровно 37 символов и код ведет себя согласно спеку. В любом ином 
случае (36 или меньше символов либо 38 или больше символов) у нас 
есть баг. 


о рая 


Поле пароля (раззиогайе!а) 


Это однострочное поле для ввода текста с тем нюансом, что каждый 
символ, введенный в это поле, тут же автоматически преобразуется в 
* (звездочку, или, по-англ. — а51егіѕк) либо в жирную метку (Бийе!). 


Преобразование в звездочки (или буллеты) сделано для того, чтобы 
какой-либо добрый, сердечный человек не подсмотрел ваш пароль и 
не очистил ваш, например, банковский эккаунт. 


Кстати, 

важной вещью в отношении пароля я&чяется профессиональная этика, 
согласно которой нужно демонстративно отворачивать голову на 
90 градусов в другую сторону от клавиатуры, если кто-то вводит 
пароль. Смотреть на клавиатуру, когда кто-либо вводит пароль, так 
же неприлично, как сказать о блефе, после того как вы выиграли 
партию в покер и карты уже перемешаны. 
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Еще одна мысль 


во множестве западных компаний каждый ваш удар по клавишам 
клавиатуры (Кеуѕігоке) невидимо для вас запечатлевается в 
текстовом файле (69), который является собственностью компа- 
нии и который, если будет нужно (естественно, не во благо вам), 
будет поднят вашим менеджером и проанализирован. 


Впрочем, так же могут быть подняты и проанализированы скрин- 
шоты (снимок изображения на экране вашего монитора), которые 
делаются с определенным интервалом (например, 60 секунд) и 
также являются собственностью вашего работодателя. 


Кстати 

если уж заговорили об осторожности: в США недавно был создан 
судебный прецедент, согласно которому все содержимое папок е- 
мейла работника является собственностью работодателя, на это 
содержимое не распространяются законы о защите частной жизни 
(рИмасу), и соответственно работодатель может спокойно про- 
сматривать всю вашу корреспонденцию, посланную с рабочего е- 
мейла или полученную на него. 


Так что не теряйте бдительности, товарищи, блоги и личная 
переписка могут подождать до вечера. 


В отношении проблем: 


размер поля пароля (МАХТ.ЕМСТН), т.е. максимальное коли- 
чество символов, которые можно ввести в него, может быть 
больше или меньше, чем указано в спецификации. 


Я имя ниспадающего меню: 


Я первое значение списка У 


Я первое значение списка 


Я второе значение списка 


Я третье значение списка 


Ниспадающее меню (ри// 4оит тепи) 
Ниспадающее меню дает возможность выбрать одно, и только одно, 
значение из списка значений меню. Наитипичнейший пример — 
ниспадающее меню со списком стран на веб-форме регистрации. 
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Я имя радиокнопки: о 
И я тоже имя радиокнопки: о 
либо 

Я имя радиокнопки: о 
И я тоже имя радиокнопки: о 


Радиокнопка (ғайіо Бийоп) 


Радиокнопка, также известная под неудобоваримым именем "зави- 
симая кнопка", — это элемент веб-формы, который позволяет 
выбрать одно, и только одно, значение из списка своих собратьев. 
Список называется группой радиокнопок, которая объединена 
одним названием и/или логичной принадлежностью к группе. Зна- 
чения радиокнопок взаимоисключаемы, и, таким образом, кнопки 
взаимосвязаны. 


Кстати, 


согласно ууу. тиЙйгап.ги английское название выбрано по ана- 
логии с кнопками выбора диапазона волн радиоприемника, когда в 
каждый текущий момент может быть выбрана только одна волна. 


Пример 
возьмем группу под названием "Пол". Может быть либо так: 


Пол: 
Муж. © Жен. О 


либо этак: 


Пол: 
Муж. О Жен. < 


В отношении терминологии. 


Можно выбрать (5е/ес!) радиокнопку: 


в первом случае — «выбрали радиокнопку "Муж."», во 
втором случае — «выбрали радиокнопку "Жен."». 


Радиокнопка может существовать только как элемент группы (2 и 
больше) взаимоисключаемых собратьев, в случаях же когда элемент 
один или элементы взаимонезависимы, используется чекбокс. 
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Я имя чекбокса (кстати, мой чекбокс не отмечен) 


И я имя чекбокса (мой чекбокс отмечен): 


41610 


Я тоже имя чекбокса (мой чек-бокс отмечен): 


Чекбокс (слескђБох) 


Чекбокс, также известный под неудобоваримым именем "независи- 
мая кнопка", — это элемент веб-формы, который позволяет: 


установить галочку (сйеск) либо 
убрать галочку (ипсйеск). 

Иными словами, можно соответственно: 
отметить чекбокс, 


очистить чекбокс. 


Чекбоксы, как и радиокнопки, могут быть сгруппированы под 
одним именем (в примере ниже именем является "Причины за- 
крытия эккаунта"), но чекбоксы, как правило, независимы друг от 


друга. 


"" 


"Как правило ", так как иногда веб-мастера предусматривают (с 
помощью Јауахсгірі) взаимосвязь между чекбоксами. 


Вот веб-форма опросника при закрытии счета: 


Причины закрытия эккаунта: 


Сайт работает слишком медленно 


Неудовлетворительная служба поддержки Сбои в 
работе веб-сайта Ограниченный выбор книг 


Проблемы с доставкой Другое: 


сарсари сари 
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Я имя кнопки!!! 


Кнопка (Рийоп) 


Нажатие на кнопку является заключительным аккордом при запол- 
нении веб-форм. Нажимая на кнопку, мы отправляем веб-форму для 
обработки на сервер с приложением (аррйсапоп 5егует). 


Кстати, 


в большинстве случаев наличие ошибок при заполнении формы (напри- 
мер, обязательное для заполнения текстовое поле "Имя " пустое) 


проверяется не на сервере с приложением, а на компьютере пользо- 
вателя. 

Это делается путем кода Јауа$стірі, являющегося частью НТМІ-стра- 
ницы с веб-формой, и в случае ошибки в заполнении формы 


выдается сообщение об ошибке, 
веб-форма не посылается на сервер с приложением. 


Если неизвестно название кнопки, то при написании тест-кейсов 
просто напишите "отправьте форму" ("зиртй іле јоғт " или просто 
"зибти"). 


АТТАСНМЕМТ (ПРИЛОЖЕНИЕ) 


Нет лучшей вещи при обмене информацией, чем хорошо подоб- 
ранная иллюстрация, особенно наглядная иллюстрация. Наш мозг 
гораздо быстрее воспринимает зрительную информацию, чем 
текстовую, и мы, зная этот научный факт, можем организовать 
эффективную презентацию проблемы. Презентация может де- 
латься, например, путем приложения снимка экрана (скриншота), 
на котором видна проблема. Вот самый технически элементар- 
ный и повсеместно распространенный способ для собственно- 
ручного изготовления скриншота: 


На клавиатуре нажимаем кнопку РиЁ5сти. 

Открываем стандартную программу Виндоуз, Ра. 
Нажимаем Сї/+у. 

Сохраняем графический файл (с расширением Јрее или .211. 
Прилагаем его к багу. 


навар 


Кстати, как Райф так и другие графические редакторы позволяют об- 
вести, например, красным цветом место на скриншоте, где видна про- 
блема (например, группу радиокнопок, которые можно выбрать одно- 
временно). В общем большое поле для творчества. 
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Естественно, что приложением может быть не только наглядная 
иллюстрация в виде графического файла, но и любые другие 
файлы, которые помогут программисту быстрее и точнее понять 
суть проблемы. 


Иногда бывают ситуации, что трудно описать проблему на род- 
ном языке, не говоря уже об иностранном. Что делаем? Прила- 
гаем файл с иллюстрацией проблемы в поле "Описание и шаги 
для воспроизведения проблемы" и скромно пишем "Смотри при- 
ложение" (5ее айасһтепі). 


Кстати, фраза "Смотри приложение" должна быть в поле "Опи- 
сание и шаги..." в любом случае — чтобы каждый, кто просмат- 
ривает занесенный вами баг, наверняка открыл и приложение. 


ЅОВМІТТЕР ВУ (АВТОР БАГА) 


СТБ автоматически присваивает значение этому атрибуту. Как 
нетрудно догадаться, значение "$иђтиійїеа Бу " — это нередакти- 
руемый текст с именем товарища, занесшего баг в СТБ (товарищ 
далее именуется автором бага). Как правило, автором бага явля- 
ется тестировщик. 


РАТЕ 5ОВМПТЕД (ДАТА И ВРЕМЯ ПОЯВЛЕНИЯ БАГА) 


Как и в случае с бибтишеа Бу, СТБ автоматически присваивает 
значение этому атрибуту. Как нетрудно догадаться, значение 
"Рае ѕиртійеа" — это нередактируемый текст с датой и време- 
нем, когда баг был занесен в СТБ своим отцом — автором. 


АЅЅІСМЕР ТО (ДЕРЖАТЕЛЬ БАГА) 


Каждый открытый баг в каждый конкретный момент имеет 
своего конкретного держателя (Оупег). Держатель бага — это 
участник процесса разработки ПО, на котором лежит ответствен- 
ность сделать следующий шаг на пути к закрытию бага. Вариан- 
ты следующего шага определяются процессом. 


Когда баг заносится в СТБ, то автор бага обязательно должен вы- 
брать имя из списка ниспадающего меню "А5у5епей ѓо " (СТБ вы- 
даст ошибку, если имя не выбрано). Список "Аѕѕісией іо " состоит 
из имен всех пользователей, кто имеет эккаунты в СТБ. Напри- 
мер, мое имя пользователя в СТБ может выглядеть как г ѕауіи. 
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Кстати, счета в СТБ открывает администратор СТБ, который, как пра- 
вило, является вашим коллегой-тестировщиком, корпящим в соседнем 
отсеке по другую сторону серой стенки, украшенной постером с сило- 
вой подачей Марии Шараповой. 


Если автор бага 


. незнает, кто из программистов должен ремонтировать этот 
баг, или 
• вообще не знает, что ему делать с этим багом, 


Ц 


то он просто выбирает из "А551епе4 іо " самое родное и близкое, 


что он может там найти, —Щ свое имя. 


В каждой интернет-компании на интранете должна быть стра- 
ничка "Кто за что ответствен" (йо доеѕ И’йай. На этой стра- 
ничке должны быть перечислены: 


• компоненты веб-сайта (те же, что и в атрибуте "Компонент", 
о нем чуть позже); 

• программисты, которые отвечают за эти компоненты; 

• продюсеры, которые отвечают за эти компоненты. 


Пример 


А тетт я 
Ю. Тимофеев, И. Николаев |В. Жабров 


Нужно, чтобы эта страничка постоянно поддерживалась, напри- 
мер, менеджерами программистов и продюсеров, чтобы отражать 
текущее состояние компонентов и ответственных лиц: 


если в компании 3 человека, сидящие в одном закутке 4х3 метра, 
то каждый примерно знает, что делают двое других. Если же 
компания растет и развивается, работники приходят, перево- 
дятся с участка на участок, уходят, функциональности появля- 
ются, модифицируются, исчезают... в общем перемены бьют 
ключом, то наличие централизованного источника информации 
о программистах и продюсерах — собственниках функцио- 
нальностей является наиудобнейшей и наиполезнейшей вещью 
(хотя бы для того, чтобы быстро и правильно выбрать имя из 
"Аѕѕіспей іо "). 
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Кстати, автором бага может быть не только тестировщик. Любой поль- 
зователь СТБ, имеющий право (римеде) на занесение багов в СТБ, 
может быть автором бага. Технически права даруются (как, впрочем, 
и отнимаются) администратором СТБ. 


Кстати, выражение "занести баг" по-аглицки звучит как "е а Бид" или 
"еройа Бид". 


Кстати, программисты часто заносят баги против своего же кода. Это 
не мазохизм, а холодный расчет, так как 


• содной стороны, сохранять баги в СТБ просто удобно, а 

• с другой — программист должен тратить время на ремонт бага, и 
баг, занесенный в СТБ, оправдывает такую трату в глазах началь- 
ства, коллег и семьи. 


Кстати, программисты любят играть багом в пинг-понг, меняя значе- 
ние Аѕѕідпеа іо на имена друг друга, говоря таким образом: "Это, доро- 
гой, не мой, а твой баг", "Нет, я думаю, что это как раз твой баг", "Я не 
уверен, что ты прав. Этот баг все-таки твой" и т.д. Результатом таких 
игр является задержка в фиксировании бага. 


Небольшой нюанс. Люди приходят в интернет-компанию и уходят 
из нее. Когда они приходят, администратор СТБ создает им счета, 
а когда они уходят, то эти счета НИКОГДА не удаляются: админист- 
ратор СТБ просто маркирует счет бывшего коллеги как недействи- 
тельный, т.е. им нельзя больше пользоваться. При этом имя пользо- 
вателя СТБ в списке пользователей СТБ остается. Принцип неудале- 
ния нужен для сохранения данных, связанных с занесенными багами. 


АЅ5ІСМЕР ВҮ(ИМЯ ПЕРЕДАВШЕГО БАГ) 


Значение этого атрибута (как и 5иртійеа Бу) является нередактируе- 
мым текстом. СТБ автоматически присваивает атрибуту А551епей Бу 
имя пользователя СТБ, который выбрал значение 551епе4 іо. Таким 
образом, счастливчик, который стал А551епеа іо, всегда знает, кто 
был тем доброжелателем, который сделал его держателем бага. 


ТЕМНЕЕ (ИМЯТОГО, КТО ДОЛЖЕН ПРОВЕРИТЬ РЕМОНТ) 


Это ниспадающее меню с тем же списком имен сотрудников, что 
и в 455іспей 10. 


Как мы помним, баг может быть занесен в СТБ любым сотрудни- 
ком интернет-компании, который имеет счет в СТБ и соответст- 
вующую привилегию. 


При занесении бага значение Гетйег автоматически становится 
равным имени автора бага. После того как баг был зафиксирован 
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И отремонтированный код был доставлен на тест-машину, держа- 
телем бага должно стать лицо, указанное в Гегйег. 


Как правило, если баг заносится не тестировщиком, то "нетести- 
ровщик" сразу (при занесении) выбирает значение Ге’\ег, чтобы 
умыть руки и позабыть об этом баге навсегда. 


Кстати, каждый эккаунт в СТБ принадлежит к определенной группе. 
Как минимум таких групп 3: 


•  "Тестировщики" — сотрудники департамента качества; 
• "Программисты" — сотрудники департамента программирования; 
• "Прочие" — все остальные. 


В зависимости от принадлежности эккаунта к определенной группе 
определяются его привилегии. Например, закрыть баг может только 
тот, кто принадлежит к группе "Тестировщики". 


Кстати, можно настроить СТБ так, чтобы, когда "Прочие" заносят баг, 
значение Мепйег не становилось автоматически равным Зибтйеа Ву, а 
было пустым и "Прочие" обязаны (под страхом незанесения бага) вы- 
брать значение Мепйег. 


Не будем больше о привилегиях, это отдельная песня, зависящая 
от компании и возможностей СТЬ. 


СОМРОМЕМТ(КОМПОНЕНТ) 


Это ниспадающее меню со списком, как правило, функциональ- 
ных частей веб-сайта. Например, этот список вполне может быть 
таким вот коротким и скромным: 

"Регистрация 

Поиск 

Корзина 

Оплата 

Другое" 


При занесении бага в СТБ автор бага должен выбрать компонент, 
тестируя который он нашел заносимый баг. Что я могу еще сказать?.. 


ЕОИМР ОМ(ГДЕ БЫЛ НАЙДЕН БАГ) 


Это ниспадающее меню, которое включает 


• имена тест-сайтов, обитающих на нашей тест-машине; 
• скромное слово "2ЈЕЈ" (машина для пользователей); 

• рес ("Спек"); 

• Ошег ("Другое"). 
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Например, в нашем любезном сердцу проекте (игу. ѓеѕіѕйор.гѕ) 
список Ёоипа оп состоит из следующих друзей: 


"илилих О АЛез15йор.т, 
улууу таїп.1еѕіѕћор.т, 
ПУЕ, 
рес, 

Олег". 


Понятно, что если значение Коипа оп равно "ГУЕ", то это означа- 
ет, что был пропущен баг, который через релиз добрался до ма- 
шины для пользователей или, как говорят некоторые любители 
повыпендриваться, "Баг вышел на продакшн". Ғоипа оп является 
обязательным для заполнения. 


Немедленная польза от использования атрибута ЕоипА оп заклю- 
чается в том, что каждый, кто хочет воспроизвести занесенный 
баг, знает, где конкретно это можно сделать. 


ГЕВУЮМ ЕООМР 
(ВЕРСИЯ, В КОТОРОЙ БЫЛ НАЙДЕН БАГ) 


Это ниспадающее меню с версиями веб-сайта, автор бага обязан 
выбрать значение, соответствующее номеру версии продукта, в 
которой был найден баг. 


ВИП ЕООМР (БИЛД, В КОТОРОМ БЫЛ НАЙДЕН БАГ) 


Это небольшое (примерно 10 символов) текстовое поле, куда ав- 
тор бага обязан вбить номер билда, в котором был найден баг. 


УЕК5ІОМ ЕІХЕР (ВЕРСИЯ С ПОЧИНЕННЫМ КОДОМ) 


Это ниспадающее меню с версиями веб-сайта. После того как 
программист починил баг, он должен передать этот баг далее (ре- 
лиз-инженеру), для того чтобы в итоге ГетйЙег произвел регрес- 
сивное тестирование (у нас будет подробное объяснения процес- 
са через 5 минут). Программист обязан выбрать номер версии, 
соответствующий бранчу в СУ, куда он направил отремонтиро- 
ванный код. 


Гегуоп Еіхеа может иметь, как одно из значений, "М/А " (№1 ар- 
рйса Ме — "к данной ситуации неприменимо"), которое продюсер 
обязан выбрать, зафиксировав баг, найденный в спеке. 
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ВОПО ИХЕР 
(БИДД С ПОЧИНЕННЫМ КОДОМ) 


Это небольшое (например, 10 символов) текстовое поле, которое 
заполняется в то же время, что и /егѕіои Еїхеа, т.е. после починки 
бага и помещения починенного кода в СУ5. В Вийа Ехей про- 
граммист обязан указать номер следующего билда, который под- 
хватит исправленный код из СУ5. Так, если 


• номер последнего билда на или’. тат ѓеѕіѕћор.тѕ равен 114, 
• билд-скрипт для нового билда стартует в 16:00 и 
• программист направил код в СУ5 в 15:30, 


то билд 115 должен содержать исправленный код из СУ и, 
следовательно, программист должен вбить в Вийа Еіхеа значение 
"115". 


Очень очевидный и очень важный момент, о которым мы уже 
говорили: перед началом регрессивного тестирования Гетйег 
должен удостовериться, что версия и билд на тест-машине 
соответствуют значениям атрибутов Гегуюпн Нхей и Вийа Еіхей 
для данного бага. 


СОММЕМТ$ (КОММЕНТАРИИ) 


Это многострочное текстовое поле, куда любой имеющий счет в 
СТБ и соответствующую привилегию может занести свои ком- 
ментарии, пояснения, уточнения и т.д. 


• обаге и/или 
• своих действиях в отношении бага. 


В некоторых случаях комментарий должен быть обязательным 
для заполнения, например когда программист возвращает баг 
тестировщику, так как считает, что это вовсе не баг. 


ЅЕҮУЕКІТҮ (СЕРЬЕЗНОСТЬ БАГА) 


Форма: ниспадающее меню со значениями от О до С4 (51—4) 
включительно. 


Содержание: серьезность бага — это степень воздействия бага 
(паспииае оѓ ітрасі) на ПО, исходя из принадлежности бага к 
определенной технической категории. 
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Вот пример категоризации: 


Серьезность бага Определение 


СІ — Критический (СийсаЙ) критический системный сбой (сгаѕ/); 
потеря данных (даа 1055); 
проблема с безопасностью (5есигИу іѕѕие) 


С2 — Значительный (Мајог) • сайт "зависает" (5Йе лапеѕ); 


• баг блокирует кодирование, тестирование 
или использование веб-сайта (Б/осКег) 


СЗ — Умеренный (Міпог) • функциональные проблемы (ўипсіїопа! Биз) 
С 4 — Косметический (Созтейс) | • косметическая проблема (соѕтеііс ргоЫет) 


Примеры 
С1— КРИТИЧЕСКИЙ 


Критический системный сбой — ситуация, когда какая-то часть ПО на 
машине для пользователей "рушится" — например, нажимаете на кнопку 
"Поиск" и получаете ошибку "НТТР Егог 500 тета! ѕегуег еггог". 


Потеря данных (даїа 1055) — чаще всего это происходит, когда данные: 


а) не достигают базы данных либо 
6) незапланированно удаляются из нее. 


Например: 
а) при регистрации е-мейл пользователя не вставляется в опреде 
ленную колонку определенной таблицы базы данных; 


6) при обновлении пользователем адреса на фронтенде старый 
адрес удаляется из базы данных. 


Проблема с безопасностью — например, когда после логина пароль виден 
как часть ОРІ, так что кто-то может подсмотреть пароль и ис- 
пользовать его в своих корыстных целях. При современном состоянии дел 
в Интернете, когда 4% монетарных транзакций осуществляется 
мошенниками, безопасность — вещь первостепенная. 


С2 — ЗНАЧИТЕЛЬНЫЙ 


Веб-сайт "зависает" — одна из основных бед интернет-проектов, на- 
пример, нажимаешь на кнопку "Купить", и следующая страница грузится, и 
грузится, и грузится... Как правило, после таких "загрузов" очень хочется 
попробовать веб-сайт конкурента. 


Баг блокирует кодирование, тестирование или использование вебсайта 
— ситуация, когда 

работа тестировщика (и/или программиста) и/или 

использование веб-сайта 


не могут быть продолжены, так как на одном из этапов появляется про- 
блема, превентирующая дальнейшее продвижение. 
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Например, пользователь не может добавить кредитную карту к своему 
эккаунтуи, следовательно, не может ничего купить на нашем веб-сайте. 


Термин "блокирование" также связан с понятием "обходной путь" (могК- 
агоипа), а вернее, с отсутствием этого пути. Например, согласно тест- 
кейсу нужно создать эккаунт путем использования тест-тула, но тест-тул 
не работает (баг в тест-туле является абсолютно легитимным багом!). 
Если есть возможность найти обходной путь, который разблокировал бы 
в данной ситуации тестирование, то баг не является блокирующим и не 
подходит под С2. Примером обходного пути в данном случае является 
создание эккаунта вручную. 


СЗ — УМЕРЕННЫЙ 


Функциональные проблемы (іипсіопа! Бидз) — под эту категорию 
подходят все функциональные баги, не подходящие под С1 и С2. Как 
правило, это простое расхождение между фактическим и ожидаемым 
результатами, когда все шаги тест-кейса (все этапы флоу) исполнены. 


СА — КОСМЕТИЧЕСКИЙ 


Косметическая проблема — баги, связанные с содержанием вебсайта 
(сопіепі), правописанием (5ре!тд) и интерфейсом пользователя (Ш5$ег 
епасе). 


Значение серьезности бага обязательно должно быть выбрано из 
списка, иначе баг нельзя занести в СТБ. 


РКІОРІТУҮ (ПРИОРИТЕТ БАГА) 


Форма: ниспадающее меню со значениями от Ш до П4 (Ш—4) 
включительно. 


Содержание: приоритет бага — это показатель важности бага 
для бизнеса компании. 


Кстати, многие товарищи путают приоритет и серьезность. Ко- 
ренное различие между ними кроется в том, что серьезность 
отражает технический аспект бага, а приоритет — коммер- 
ческий. 


Серьезность — это категория абсолютная. Приоритет — это 
категория относительная. 


Так, если сайт рушится (сғаѕћ), то это С1, и мы не можем, на- 
пример, по политическим соображениям изменить серьезность 
такого бага, например, на С2, так как ситуация (с системным 
сбоем) четко соответствует дефиниции СІ. Если же тести- 
ровщик назначил приоритет как ПІ, то программист вполне 
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может оспорить такое решение и в итоге приоритет будет П2. 
Таким образом, назначение серьезности — это механическое дей- 
ствие, а приоритета — творческое, связанное с оценкой угрозы 
бага для бизнеса компании. 


Часто в документации процесса и настройках СТБ определена 
четкая связь между верхними значениями серьезности и приори- 
тета. 


Например, если установлено, что "при серьезности С1 значение при- 
оритета должно быть ПЛ", и тестировшик выбирает С1 и П2, то СТБ не 
позволит занести баг и выдаст ошибку. 


В большинстве же случаев, т.е. при СЗ (функциональных) багах, 
нет четкой зависимости между серьезностью и приоритетом, и в 
"Описании и шагах..." иногда стоит объяснить, почему вы 
выбрали именно этот приоритет, а не более высокий или более 
НИЗКИЙ. 


Кстати, П1 — баг, из-за которого может сорваться запланированный 
релиз, называется ѕһоиѕіоррег ("пробка"). Примером такого бага мо- 
жет служить ситуация, когда тестирование функциональности "Оплата" 
полностью заблокировано из-за бага во вспомогательном ПО, симули- 
рующем платежную систему. 


Еще пара слов о связи серьезности и приоритета бага: например, 
мы имеем дело с судопроизводством, а не интернет-проектом. 
Фраза "казнить нельзя помиловать" содержит баг, так как от- 
сутствует запятая. Отсутствие запятой — это С4, но ситуация, 
когда может быть наказан невиновный или оправдан преступник, — 
это ПІ. Ну, например, из-за величины негативных последствий 
для имиджа правосудия (шутка). 


Кроме привязки к серьезности бага на приоритет могут воздейст- 
вовать следующие потенциальные либо реальные вещи: 


• процент затронутых пользователей, 

• денежные потери для компании, 

• негативные юридические последствия для компании, 
• негативные последствия для имиджа компании. 


В каждой компании должны быть дефиниции приоритета багов 
(Биг ргіотіі аеўпійопѕ), в которых обязательным элементом яв- 
ляется указание сроков для починки багов (дополнительным эле- 
ментом могут быть факторы, указанные выше, например процент 
затронутых пользователей). 
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Вот простейший пример дефиниций. 


Брось все дела и зафиксируй баг 
Зафиксируй баг в течение 72 часов 


ПЗ Зафиксируй баг до завершения тестирования данного 
основного релиза 


Зафиксируй, если возможно 


Примеры 
П1—П2 — все понятно. 
ПЗ — каждая стадия цикла разработки ПО имеет свои запланирован- 


ные временные рамки. Таким образом, если релиз должен состояться 
16 марта, то до 16 марта все ПЗ должны быть зафиксированы и закрыты. 


П4 — такие баги фиксируются, если у программиста есть время. На- 
пример, в какой-нибудь старой версии браузера интернет/эксплорер 
(Іпіетеѓ Ехріогег — ІЕ) не работает какое-нибудь суперзамысловатое 
флоу, которое вряд ли может прийти кому-либо в голову. 


У каждой компании есть свои заморочки, но, как правило, все баги ПТ, 
П2 и ПЗ должны быть зафиксированы и закрыты до релиза. 


В случае с ПЗ, если не хватает времени, может приниматься решение о 
релизе, содержащем баг, с условием, что в течение такого-то периода 
времени (дни) этот баг будет зафиксирован, протестирован и патч- 
релиз выпущен на машину для пользователей. 

Почему принимается такое решение, которое, казалось бы, противо- 
речит здравому смыслу? 

Очень просто. Политика, господа: акционеры компании ждут доходов 
от своих инвестиций, и каждый основной либо дополнительный релиз — 
это потенциальный катализатор новых прибылей, и такие вещи, как пароч- 
ка незафиксированных ПЗ, в мире чистогана в расчет не принимаются. 
Кроме того, менеджменту придется держать ответ перед теми же акцио- 
нерами, почему релиз не был выпущен вовремя. 

Иногда опять же по политическим соображениям принимается реше- 
ние о понижении приоритета бага со всеми вытекающими отсюда по- 
следствиями, например, когда П2 понижается до ПЗ и этот ПЗ выпус- 
кается на продакшн. 


Приоритет обязательно должен быть выбран из списка, иначе баг 
нельзя занести в СТБ. 


В случае сомнений в том, какой приоритет поставить, например 
ПЗ или П2, я обычно иду по пути повышения приоритета, т.е. 
выбираю П2. Как говорится, не корысти ради, а во благо наших 
дорогих и любимых пользователей. 
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Иногда возникают конфликтные ситуации, когда программист 
считает, что приоритет завышен, а тестировщик утверждает, что 
"сам ты такой" и приоритет назначен правильно. В таком случае 
вы можете попросить своего менеджера принять решение о сни- 
жении приоритета, если вы считаете, что поставленный вами 
приоритет верен и не хотите снижать его сами. Помните, что 
дружба дружбой, а если вы были заблокированы и из-за люб- 
ви к своему программисту поставили ПЗ вместо Ш, то про- 
блемы с невыполнением плана будут у вас, а не у него, так 
как это вы, а не он можете не закончить в срок исполнение 
тестирования. 


Приоритет — это мощнейший инструмент, используя который вы 
влияете на расписание работы программиста, поэтому не зло- 
употребляйте им (приоритетом) и используйте его мудро. 


МОТШЕУ [15Т (СПИСОК ДЛЯ ОПОВЕЩЕНИЯ) 


Это ниспадающее меню со списком алиасов всех пользователей, 
зарегистрированных в СТБ. Во многих случаях тестировщику не- 
обходимо, чтобы 


• о факте занесения бага и 
• о любом изменении в самой записи о баге 


знал определенный круг людей. 


Оповещение происходит с помощью е-мейла, В который вклю- 
чаются: 


• номер бага; 

• статус; 

• краткое описание; 

• приоритет; 

• серьезность бага; 

• название, старое и новое значение измененного атрибута 
(например, кто-то занес свое мнение в комментарий); 

• имя того, кто покусился изменить баг (либо занести новый 
баг в СТБ). 


Кстати, 


каждый пользователь СТБ может отрегулировать настройки оповеще- 
ния как ему удобно, например, можно сделать так, чтобы е-мейл посы- 
Лался каждый раз, когда заносится баг, упоминающий в кратком опи- 
сании некий спек, например, за номером 7611. 
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Как правило, по умолчанию 
• после занесения бага е-мейл посылается 


автору бага и 
держателю бага, 


• апри изменении записи о баге — 


автору бага, 
держателю бага и лицу, 
изменившему баг. 


Настройками оповещения, общими для всех участников процес- 
са, ведает, как вы уже догадались, администратор СТБ. 


Таким образом, атрибут "Список для оповещения" используется 
автором бага либо другим заинтересованным лицом для того, 
чтобы е-мейлы посылались тем, кто не является реципиентом 
по умолчанию. 


Я всегда включаю в "Список для оповещения" имя продю- 
сера, чтобы тот знал о состоянии дел, связанных с тестирова- 
нием его спека. 


Выбор значений для данного атрибута не является обязательным. 


СНАМСЕ НІЅТОВҮ (ИСТОРИЯ ИЗМЕНЕНИЙ) 


Это наиважнейший, автоматически заполняемый атрибут. Суть 
его в том, что любое изменение бага отражается в нередактируе- 
мом многострочном текстовом поле в следующем формате: 


• дата и время изменения (даѓе апа йте оГсйапее); 

• имя лица, изменившего баг (ило срапзеа); 

• название измененного атрибута (ийа! миаз сћапееа); 
• предыдущее значение атрибута (ргеуіоиѕ уаіие); 

• новое значение атрибута (пеу уа/ие). 


Запомните, что любые действия любого лица, имеющего счет в 
СТБ, автоматически записываются, запись доступна для всех 
пользователей СТБ и не подлежит редактированию. Таким обра- 
зом, можно до секунды увидеть, что конкретно, как конкретно и 
кем конкретно было изменено. Анонимность, столь любимая по- 
сетителями интернет-форумов, полностью исключена. 
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ТҮРЕ (ТИП БАГА) 


Это ниспадающее меню со значениями: 


• Бис (баг), 
• Јеаѓиге гециезі (запрос о фича). 


По умолчанию значение типа бага (типа записи) — это "баг", т.е. 
расхождение между фактическим и ожидаемым результатом, и 
95% багов (записей) в СТБ имеет значение "баг". 


Компьютерный термин "Ееаѓіиге " не имеет эквивалентного тер- 
мина в русском языке, и мы можем 


• либо изобрести новое слово, 

• либо позаимствовать существующее слово из английского 
языка и соответственно писать его русскими буквами (что 
мы и сделаем). 


Я всегда стараюсь найти подходящий перевод английской тер- 
минологии, но иногда это просто не удается, и хотя заимство- 
ванные слова, написанные кириллицей, могут поначачу коробить 
слух и глаз, это вещь вполне легитимная. Например, книга Васи- 
лия Аксенова "В поисках грустного бэби" изобилует такими сло- 
вами, так как многие из них просто невозможно правильно пере- 
вести (например, "плаза "). Кроме того, есть термины, устояв- 
шиеся в профессиональной среде (например, наша "фича "). 


Итак, фича — это в зависимости от контекста 


• функциональность либо 
• характеристика (или свойство) компонента кода, интер- 
фейса, базы данных и пр. 


Например 


Значение "функциональность" работает, если мы говорим о кепча. 
Значение "характеристика" работает, если мы говорим об оптимиза- 
ции кода с целью улучшения перформанса (скорости работы сайта). 


Обратно к Реаиге ғедиезі. 


Баг с типом Ғеаѓиге гедиеѕі заносится в СТБ с именем продюсера 
или программиста в 4Аѕѕіспеа іо, когда у вас родилась идея об 
улучшении некой существующей фича или о новой фича. 


Значение типа Решиге гедиеѕі также используется в баге, служа- 
щем основанием для патч-релиза, в случае, когда появилась не- 
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обходимость в срочном изменении кода на машине для пользо- 
вателей и это изменение не связано с багом (как отклонением 
фактического от ожидаемого). 


Логичным будет вопрос: почему мы употребили выражение 
"срочное изменение"? 

Вот ответ: если нужна новая функциональность, то продюсер 
пишет спек, программист его кодирует и т.д. в соответствии с про- 
цессом разработки ПО. Каждая стадия процесса имеет свои вре- 
менные рамки, которые привязаны к расписанию релизов (7е/еаѕе 
5спедше). А что, если у нас появилась незапланированная потреб- 
ность в новой фича и ее нужно срочно выпустить? 


Пример 


Допустим, мы выпускаем один основной релиз в месяц. Сегодня 10 
ноября, и последний основной релиз (7.0) состоялся 31 октября. 
Если сегодня (Ю ноября) появилась новая идея (например, о добавле- 
нии кепча на страницу регистрации), то если мы включим ее в наш 
процесс разработки как любую очередную идею, то наша многостра- 
дальная кепча появится на машине для пользователей не 1 декабря в 
релизе 8.0 (так как все спеки релиза 8.0 уже заморожены), а 1 января 
в релизе 9.0. Таким образом, придется ждать больше полутора меся- 
цев. Что делать, если у нас нет полутора месяцев, а есть полтора часа ? 
Нужно занести баг "Реашге гедие$!" с приоритетом П1. Если же фича 
может подождать до 8.0, то опять же заносим баг с типом "Ееаїиге ге- 
диеѕі", но уже с приоритетом ПЗ. 


Вот такие дела... 


ЅТАТОЅ (СТАТУС) 


Это ниспадающее меню со значениями: 


• Ореп (Открыт), 
• С1оѕеа (Закрыт), 
• Ве-Ореп (Повторно открыт). 


Значение Ореп присваивается багу автоматически при занесении бага. 


Закрыть баг можно только при соответствуюшей резолюции (об этом 
через минуту). 


Значение Ке-Ореп выбирается тестировщиком, когда он возрож- 
дает к жизни закрытый баг. 


Почему возникают ситуации, когда баги приходится открывать 
заново? 
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Например 


• программист сделал изменение в коде и поломал отремонтиро- 
ванный ранее код, так что проблема появилась заново. В этом слу- 
чае говорят о том, что баг был геіпігоаисеа ("заново внесен на рас- 
смотрение" — так себе перевод, но ничего лучше я не нашел); 

• баг был найден на машине для пользователей. Программист сде- 
лал сһескіп отремонтированного кода в бранч-версии машины для 
пользователей и позабыл сделать сһескіп в ствол. Следовательно, 
в следующем релизе баг появляется снова. 


В связи со статусом запомним две вещи: 


• ВСЕ найденные баги должны заноситься в СТБ. Исклю- 
чений быть не может. Ваша работа как тестировщика — 
искать баги. Единственный и неповторимый результат вашей 
работы — баг, занесенный в СТБ. Умные программисты ни- 
когда на вас не обидятся, так как качество их работы измеря- 
ется не количеством багов, ими допущенных, а скоростью, 
с которой они эти баги чинят (почти по Глебу Жеглову); 


• занесенные в СТБ баги НИКОГДА не удаляются из СТБ. 
Чтобы ни случилось, пока живет компания, ее СТБ вклю- 
чает ВСЕ баги, найденные в продукте. Администратор СТБ 
должен настроить последнюю так, чтобы исключить воз- 
можность удаления багов пользователями СТБ. 


Таким образом, каждый баг, когда-либо найденный в продукте, 
будет иметь одно из трех упомянутых значений статуса. 


КЕЗОГОТОМ (РЕЗОЛЮЦИЯ) 


Это ниспадающее меню со значениями: 


№т Аѕѕіспей (не приписан) 

Аѕѕіспеа (приписан) 

Еіх т Рговтеѕѕ (баг ремонтируется) 

Еіхей (баг отремонтирован) 

Вийа іп Рғозтеѕѕ (билд на тест-машину в процессе) 
Ге у (проведи регрессивное тестирование) 
Вх 15 Уенрей (ремонт был успешен) 
Кегіўісайоп ЕайЙе4 (ремонт был неуспешен) 
Сап" Керғойисе (не могу воспроизвести) 
Рирйсие (дубликат) 

№ т а Биг (не баг) 

Зға рагіу Биг (не наш баг) 

№ 1опзег аррйса Ме (поезд ушел) 
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Резолюция — очень важный атрибут, напрямую связанный со 
статусом. 


Если статус — это своего рода "жив", "умер", "реинкарнировался", 
то резолюция — это "поступил в институт", "женился", "купил 
машину", т.е. резолюция — это детализация статуса. 


№т Аѕѕіопей (не приписан) 


Такая резолюция может быть после того, как баг занесен, но лицо, 
занесшее баг в СТБ, не знает, кто может этот баг зафиксировать. 


Аѕѕіспей (приписан) 


К новому багу приписан держатель (оиме!), т.е. лицо, ответст- 
венное за совершение следующего действия в отношении бага в 
соответствии с процессом. 


Как мы помним, у каждого открытого бага всегда есть дер- 
жатель. 


В случае резолюции №1 Аѕѕіспей держателем бага является автор 
бага, не передавший его дальше. 


Итак, меняем статус на 455іопеа, когда передаем баг для ремонта, 
и выбираем имя из ниспадающего меню 4Аѕѕіспей 10. 


Нх т Ргоотеѕѕ (баг ремонтируется) 


Это значение резолюции выбирается программистом, когда он 
начинает ремонт бага. Держатель бага — программист. 


Нхе4 (баг отремонтирован) 
Это значение резолюции выбирается программистом после того, 
как он 

• отремонтировал баг и 

• сохранил код в СУ. 


Держатель бага — релиз-инженер. 


Вийа т Ргорғеѕѕ (билд на тест-машину в процессе) 


Это значение резолюции выбирается релиз-инженером (а иногда 
и билд-скриптом) после запуска на тест-машину билда с отре- 
монтированным кодом, т.е. Вий т Ргоотеѕѕ приходит на смену 
Еіхей. 
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Здесь нужно заметить, что если даже баг найден на машине для 
пользователей, патч-релиз происходит только после того, как ре- 
монт протестирован на тест-машине. 


Держатель бага — релиз-инженер. 


Кегіју (проведи регрессивное тестирование) 


Это значение резолюции выбирается релиз-инженером (а иногда 
И билд-скриптом) после того, как билд на тест-машину завершен. 


Держатель бага — лицо, чье имя указано в Ге’Й\ег. Если у вери- 
фаера нет возможности проверить ремонт, то он может просто 
выбрать другое значение /егіўег так, чтобы его коллега принял 
груз ответственности. 


Их 15 Гемре4 (ремонт был успешен) 


Р егрессивное тестирования бага состоит из двух частей, следую- 
щих одна за другой в таком порядке: 


Часть 1: 
проверка того, что баг был действительно починен, т.е. 
четко следуем инструкциям из "Описания и шагов..." для вос- 
произведения бага. Если функциональность работает как сле- 
дует, то баг действительно был починен. 


Часть 2: 

проверка того, что ремонт бага не наплодил других багов. 
Код — это тонкая материя, состоящая из множества взаимо- 
зависимых компонентов, и чем сложнее ПО, тем труднее пред- 
угадать, как изменение кода в одном месте отразится на рабо- 
те всех закоулков системы. Если программист не указывает в 
комментариях, какая часть ПО может быть попутно затронута 
ремонтом, я в зависимости от ситуации 


• прохожу по приоритетному флоу функциональности, 
код которой был отремонтирован, и/или 
• делаю энд-ту-энд-тест. 


Пример с энд-ту-энд-тестом 

в функциональности корзины была проблема с тем, что пользователь 

не мог изменить количество книг. Энд-ту-энд-тест, который бы я сделал: 
а) добавить в корзину книгу, 


6) изменить количество книг и 
в) произвести оплату. 
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Таким тестом мы проверяем, что флоу, в которое включен отремонти- 
рованный компонент, все еще работает. 


Изменить резолюцию на Хх 15 Генйдей можно непосредственно 
после успешного завершения части 1. 


При значении Ёїх 15 Гемйей можно закрыть баг. После закрытия 
бага у него нет держателя, так как его некуда больше передавать. 


После того как резолюция стала Ех 15 Гемйе4 и до закрытия бага 
держателем бага является товарищ, который выбрал эту резолюцию. 


Генйсаноп Еайеа (ремонт был неуспешен) 


Если первая Часть регрессивного тестирования показала неус- 
пешность ремонта, т.е. баг все еще существует в коде, то мы не 
делаем второй части, а просто выбираем это значение резолюции, 
после чего держателем бага становится программист, который 
ПОЧИНИЛ код. 


Сап Ч Кергойисе (не могу воспроизвести) 


Эта неприятная для тестировщика резолюция выбирается про- 
граммистом после того, как перед починкой кода он пытается 
воспроизвести проблему и не может сделать этого. Как правило, 
Сап 7 Кергодисе имеет место в следующих случаях: 


• "Описание и шаги..." содержат неполную, неверную или 
нечеткую информацию о том, как воспроизвести баг, и/или 

• бага нет, т.е. тестировщик принял за баг правильно рабо- 
тающий код. 


Одной из основных вещей в отношении багов в ПО является идея 
об их воспроизводимости, т.е. если баг существует, его можно 
воспроизвести. Бывает так, что тестировщик, найдя баг в ПО, 
сразу же открывает СТБ, заносит новый баг и, довольный собой, 
продолжает работу. Программист же соответственно бросает ра- 
боту, начинает воспроизводить этот баг и после нескольких не- 
удачных попыток посылает его обратно тестировщику с резолю- 
цией Сап'ї Кергойисе. Особенно неприятна ситуация, когда опи- 
сание бага содержит сложную и долгую процедуру, необходимую 
для воспроизведения. 


Лучшим средством превентирования подобных вещей является 
правило: "Перед тем как занести новый баг, воспроизведи его 
еще раз", т.е., после того как найден баг, необходимо воспроиз- 
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вести его повторно. Это, казалось бы, простое правило поможет и 
тестировщику, и программисту быть немного счастливее, а наше 
счастье — это счастье пользователей. 


Бывают такие случаи, когда очень сложно выявить условия, ко- 
торые привели к появлению бага. 


Кстати, проведем границу между условиями возникновения бага и 
причинами возникновения бага. 

Условие появления бага — это непосредственная ситуация, воспроиз- 
ведя которую мы воспроизводим баг. Например, пользователь может 
добавить кредитную карту с датой истечения действия в прошлом. 
Причина появления бага — это конкретная ошибка программиста или 
продюсера, результатом которой является баг (например, сделана 
ошибка в логике кода). 


Идем дальше. 


Например, мы увидели баг и не можем воспроизвести его, совер- 
шая, казалось бы, те же самые действия, которые привели нас к 
багу в самом начале. После того как баг не был воспроизведен, 
мы оставляем наши попытки, так как, если баг существует, его 
можно воспроизвести, продолжаем работу, а затем снова видим 
тот же баг и снова не можем его воспроизвести. 


Что я могу сказать? Именно такие ситуации бросают вызов на- 
шему профессионализму. Если баг появился один раз и мы никак 
не смогли воспроизвести его, то после его второго появления мы 
ОБЯЗАНЫ найти условия, в результате которых он появляется. 
Такие условия есть всегда, как порой ни сложно найти их. 


бог вам история, рассказанная моим приятелем 


В одной фармацевтической лаборатории работали четыре сотрудника. 
Один из них, сотрудник М. изобрел уникальное вещество, которое 
должно было послужить основой нового лекарства. №. составил под- 
робный рецепт, но никто из его коллег не смог изготовить то же веще- 
ство, хотя они в точности выполняли все шаги. Дошло даже до того, что 
троица, стоя по бокам от Л/., повторяла все его действия, и все-таки 
вещество получалось только у него одного. В итоге четыре человека с 
университетским образованием собрались на совещание и решили, 
что они поверят в мистическое происхождение вещества, но после од- 
ного последнего теста: АБСОЛЮТНО все действия М. в процессе изго- 
товления вещества должны были быть засняты на видеокамеру и тща- 
тельно проанализированы. 


После съемки, тщательного анализа и последующих тестов разгадка 
была найдена: в процессе изготовления вещества сотрудник М. пере- 
ходил из одной лаборатории в другую по морозной улице. 
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Так как он был заядлым курилыщиком, то перед выходом на улицу, что- 
бы освободить руки для зажигалки и сигареты, он клал пробирку 
с веществом "ближе к сердцу" — во внутренний карман пиджака, 
и, таким образом, жидкость в пробирке не охлаждалась, как это было 
с коллегами М., которые не курили и переносили пробирки в руках. 


Мораль сей истории такова: порой мельчайший нюанс может иметь 
радикальное влияние на конечный результат. 


Кстати 
условием (а вернее, одним из необходимых условий) для воспроизве- 
дения вещества было недопущение охлаждения жидкости в пробирке. 


Причиной же появления того или иного итогового вещества были хи- 
мические процессы. 


Итак, стремитесь к тому, чтобы программисты никогда не воз- 
вращали вам баги с резолюцией Сап'ї гергодисе. 


Держатель — тот, кто занес баг в СТБ. 


Рирйсеие (дубликат) 


Эта резолюция выбирается после того, как повторный баг был 
занесен СТБ для той же проблемы. 


Даже в стартапах в СТБ заносятся сотни и тысячи новых багов, и 
порой физически нет возможности просмотреть каждый из них, 
так чтобы постоянно быть в курсе дел и не занести баг — дубли- 
кат уже существующего. На помощь может прийти модификация 
ваших персональных настроек СТБ, где можно предусмотреть, 
что вы будете извещаться е-мейлом о всех багах, имеющих опре- 
деленные значения определенных атрибутов (например, слово 
"корзина" в кратком описании). 


Такая резолюция позволяет закрыть баг. 


Держатель — тот, кто занес баг в СТБ. 


№1 а Биг (не баг) 


Это значение резолюции присваивается, как правило, программи- 
стом, когда возникает ситуация "И'5 пог а Бие, И5 а јеаіиге " ("это 
не баг, а фича"), т.е. тестировщик принял за баг то, что, по мне- 
нию программиста, работает правильно. 


Когда возникают подобные ситуации? Например, когда тести- 
ровщик создал тест-кейсы, руководствуясь спеком, а програм- 
мист создал код, руководствуясь чем-то иным. 
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Почему возникает "руководствуясь чем-то иным"? Из-за плохих 
спеков, когда программист фактически делает работу продюсера, 
придумывая то, как должны работать функциональности, либо же 
из-за того, что программист решает просто "забить", скажем, на 
часть спека и сделать по-своему. 


Бывает также, что либо тестировщик, либо программист, либо оба 
из них неправильно поняли спек. 


Бывает также, что программист просто "пропустил" часть спека 
и не написал для этой части код. 


Причин множество. 


Как правило, после того как программист возвращает мне баг с 
№71 а Бис, я читаю его комментарии и принимаю решение о за- 
крытии бага или возврате его программисту (меняю резолюцию 
на 455іопеа и меняю мое имя в 455іспей іо на имя программиста) 
с моими комментариями. 


Кстати, в зависимости от СТБ иее настроек значения атрибутов могут быть 


а) взаимозависимыми или 
6) нет 


Примеры 

а) значение атрибута Аѕѕідпеа іо меняется автоматически в зависи 
мости от резолюции: 
если программист выбрал Моё а Бид, значение Аѕѕідпеа іо само ме- 
няется на имя лица, занесшего баг в СТБ; 

6) значение атрибута Аѕѕідпеа іо статично: 
после того как программист выбрал резолюцию № а Вид, он дол- 
жен самостоятельно изменить значение Аѕѕідпеа іо на имя лица, 
занесшего баг в СТБ. 


Обратно к № а Биг. 


Если нужно, я уточняю у самого программиста дополнительные 
детали, и если мы не приходим к консенсусу о том, закрывать баг 
либо начать ремонт, то я меняю № а ри? на Аѕѕіспей, выбираю в 
Аѕѕіспеа іо имя продюсера и пишу в комментариях, чтобы тот 
принял решение, что с этим багом делать. 


Важный момент: если проблема была в спеке, то продюсер ста- 
новится держателем бага (после того как я изменю № а Бих на 
Аѕѕіспей и выберу имя продюсера в 4Аѕѕіспей іо), и он должен из- 
менить резолюцию на Иер после того, как спек будет изменен. 
Я поменяю резолюцию на Ёїх іѕ Гемйеа, если своими глазами 
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увижу, что спек на самом деле был изменен, изменение было 
правильным и спек находится в том месте интранета компании, 
где он должен находиться. 


Кстати, в некоторых компаниях качество работы тестировщика оцени- 
вается (конечно, наряду с прочими факторами) по тому, сколько багов 
было закрыто с резолюцией Моё а Бид от общего количества найден- 
ных им багов в том смысле, что, чем больше нот-э-багов, тем хуже по- 
работал тестировщик. 


В случае если баг, возвращенный с №: а Бис, на самом деле не баг, 
то держателем становится автор бага и баг может быть закрыт. 


Зт рағіу Биг (не наш баг) 


Во всех интернет-компаниях уже используют ПО, написанное дру- 
гими софтверным компаниями, например интерпретатор для лю- 
бимого мною языка Руѓлои. Допустим, что я нахожу баг и заношу 
его в СТБ. Программист начинает поиск причины бага и видит, 
что его код работает чики-пики и корень зла находится в "не на- 
шем" ПО, которое каким-либо образом связано с нашим кодом. 
Что делает программист? Правильно — возвращает мне баг с ре- 
золюцией 374 рагу Бир. 


Что может быть дальше? 


Вариант 1: мы не можем повлиять на производителей "не нашего!" 
ПО так, чтобы они зафиксировали свою проблему (которая стала 
нашим багом). 


Например, если проблема была в интерпретаторе Руѓлоп, то един- 
ственное, что мы можем сделать, — это найти обходной путь 
(иоткагоипа). Для того чтобы программист начал искать такой 
путь, мы должны оправдать его усилия тем, что закроем баг с ре- 
золюцией 374 раму Биг и занесем новый баг, над которым он и 
станет работать. 


Важный момент: этот новый баг будет с типом "Режиге Кециез!". 


Вариант 2: мы можем повлиять на производителей "не нашего" 
ПО так, чтобы они зафиксировали свою проблему (которая стала 
нашим багом). 


Одним из видов особей, обитающих в софтверных компаниях, 
являются менеджеры проекта (Ргојесі Мапавег ог РМ). Менед- 
жер проекта — это администратор, который отвечает за проект. 
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Основа его работы —Щ координация между такими частями про- 
екта, как идея, дизайн, кодирование и тестирование, и всеми связан- 
ными с ними нюансами типа сроков, людей и прочих ресурсов. 


Можно также провести аналогию с должностью директора кар- 
тины в советском кинематографе, который мог ничего не пони- 
мать в работе оператора, но который знач все ходы и выходы, 
чтобы достать и пленку, и аппаратуру, и самого оператора. 


Менеджер проекта — это первый и главный контакт, кото- 
рый должен быть в курсе событий, знать состояние дел и 
знать, кто за что отвечает, чтобы быстро и точно переадресо- 
вать проблему тому, кто ее может решить. 


Кстати, термин "проект" употребляется здесь (в разговоре о менед- 
жерах проекта) в двух значениях: 


• некая часть ПО, например, "Оплата". У Оплаты может быть свой 
менеджер проекта, который на постоянной основе ведает всеми 
делами, связанными с ней; 

• новая инициатива, например, под названием "Обновление архи- 
тектуры базы данных". 


Хороший менеджер проекта — это благословение проекта, пло- 
хой — его проклятие. Любимое развлечение плохих менеджеров 
проекта — организация бесконечного числа бесконечных сове- 
щаний с переливанием из пустого в порожнее. 


Кстати, я однажды подсчитал, сколько денег компания тратила на ка- 
ждое из совещаний по одному из проектов, — цифра была более чем 
внушительная. Вот формула для консервативного подсчета стоимости 
одного совещания, может быть, пригодится как-нибудь: 


10а! соѕі о тееіпд = 
=питбег о рагіісірапіѕ х теаіап һоийу га х питбег оЁ һоигѕ, 


где іоїа! соѕі о тееїіпд — сколько стоит компании одно совещание; 
питбег о? раѓїсірапіѕ — число присутствующих на совещании; теаїап 
Һоипу гаїе — средняя заработная плата в час. Заработная плата каждого 
— это вещь индивидуальная, но все равно можно прийти к некой условной 
величине, исходя хотя бы из вашей собственной заработной платы; питрег оЁ 
һоигѕ — количество часов, которое длится совещание. 


Я встречал РЛМОВ очень разных квалификаций и навыков в обще- 
нии. Бывали даже случаи, когда я шел к своему менеджеру и про- 
сил его дать мне другой проект, так как не хотел работать с неким 
конкретным менеджером проекта. 


В подавляющем большинстве случаев в стартапах обязанно- 
сти менеджера проекта исполняют продюсеры. 
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Итак, обратно к "не нашему" ПО. 


Во многих случаях наш веб-сайт так или иначе связан с ПО, ко- 
торое принадлежит нашим бизнес-партнерам и ими же поддер- 
живается в рабочем состоянии, например это ПО для процессинга 
кредитных карт. 


Так вот если найденный баг является багом в таком ПО, то тот, 
кто исполняет обязанности менеджера проекта, набирает номер 
ответственного лица на стороне наших бизнес-партнеров и коор- 
динирует действия между нашей и не нашей стороной (например, 
нашим и не нашим программистами) по разрешению проблемы. 
Может, это и не баг вовсе, а недопонимание нами, как работает 
не наше ПО. 


Если же это баг, то наш партнер заносит запись о нем в собствен- 
ную СТБ. 


Далее. 


Если это баг, то могут быть следующие варианты: 


• баг имеет место быть на не нашей тест-машине, т.е. наша 
тест-машина "разговаривает" с их тест-машиной и/или 

• баг имеет место быть на не нашей машине для пользовате- 
лей (мы выступаем в роли пользователей), т.е. наша машина 
для пользователей "разговаривает" с их машиной для поль- 
зователей. 


В зависимости от того, где был найден баг в не нашем ПО и от 
его важности для нас, а соответственно для нашего контрагента, 
назначается приоритет, от которого зависит и скорость починки. 
Всю координацию от "А" до "Я" с нашей стороны осуществляет 
тот, кто исполняет обязанности менеджера проекта. 


Итак, если мы можем повлиять на производителей не нашего ПО 
и программист вернул вам баг с резолюцией 3,0 рату Бих, вы в 
Аѕѕіспей іо выбираете имя того, кто исполняет обязанности ме- 
неджера проекта, и, сопровождая баг своими комментариями, 
делаете его держателем бага. Он со своей стороны после выясне- 
ния: "Кто виноват? Что делать? и Едят ли курицу руками?" — 
может вернуть вам баг с резолюцией №2 а Вис (если это был не 
баг, а недопонимание того, как работает не наше ПО) либо же 
вернуть вам баг (путем А55іспей іо) с той же резолюцией — 374 
рату Виз, и вы в обоих случаях спокойно его закроете. 
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Важно: в обоих случаях (когда мы не можем/можем повлиять на 
производителя не нашего ПО) наш программист может ошибочно 
допустить, что проблема в не нашем ПО, хотя на самом деле это 
наш баг. В этом случае тестировщик делает: 


Веѕоішііоп — Аѕѕіспей 
Аѕѕіспеа іо — имя программиста. 


№ [опзег аррйсаЫе (поезд ушел) 


Такое значение резолюции присваивается багу, который раньше 
действительно был багом, но теперь по какой-то причине тако- 
вым не является. 


Например 


мы исполняем тест-кейс по проверке одного из флоу функционально- 
сти "Оплата" и видим, что отсутствует поле для ввода номера СУ/2. Мы 
заносим баг и получаем его обратно с резолюцией № Ёопдег АрріісаЫ̇е 
и комментарием программиста, что согласно багу #7723 с типом "Ееа- 
ге Кедиеѕі" мы больше не должны спрашивать СУИ/2 у пользователя. 
Таким образом, до занесения продюсером бага #7723 ситуация с от- 
сутствующим СИ/2 была бы багом, а теперь это не баг. 


Баги, возвращенные с резолюцией № 1опзег аррйса е, как пра- 
вило, возникают из-за отсутствия информации. 


В моей практике, если фактический результат после исполнения 
тест-кейса расходится с ожидаемым результатом по этому тест-кей- 
су, я пытаюсь воспроизвести баг заново, и если он воспроизводится, 
то я сразу же заношу его в СТБ. Если же я вижу проблему, которая 
не связана с моим ожидаемым результатом и/или функциональ- 
ностью, о которой я имею полную информацию, то обычно контак- 
тирую с коллегами-тестировщиками, которые владеют вопросом 
о функциональности, в которой, как мне кажется, есть баг. 


Резолюция № опзег арріісаЫе позволяет закрыть баг, если он на 
самом деле больше не баг. 


Процесс трэкинга багов 


Теперь, после того как мы поговорили об атрибутах СТБ, посмот- 
рим на блок-схему. На ней мы воочию видим основу процесса 
трэкинга багов. Эта основа сама по себе является стандартной 
версией процесса, и интернет-компании используют ее в таком 
либо измененном виде. 
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Процесс трэкинга багов 


Найден новый баг!!! 


Задача 1; 
Занеси баг 
Держатель: тестировщик 


Задача 2: 
Рассмотри проблему 
Держатель: программист 


Задача 9: 
Верни баг 
Держатель: 
программист 


Задача 10: 
Рассмотри баг 
Держатель: 
тестировщик 


Задача 3: 
Отремонтируй баг 
Держатель: программист 


Задача 4: 
Срескт кода в СУ$ 
Держатель: программист 


Задача 5: 
Запусти новый билд 
Держатель: релиз-инженер 


Задача 6: 
Регрессивное тестирование 
Держатель: тестировщик 


| Задача 7: 

Баг Верни баг 

починен? программисту 
Держатель: 
тестировщик 


Задача 8: 
Закрой баг 
Держатель: тестировщик 
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Кстати, для упрощения допустим, что баг заносится тестиров- 
щиком (хотя мы знаем, что баг может заноситься кем угодно) 
и против кода программиста (хотя мы знаем, что существуют 
и баги спека, которые заносятся против продюсера). 


Давайте сделаем так: 


• сначала рассмотрим процесс концептуально, затем 

• привяжем к каждой его стадии наши атрибуты (детальное 
рассмотрение процесса), затем 

• приведем конкретный пример. 


Концептуальное рассмотрение процесса трэкинга багов 


Задача 1: После того как мы нашли проблему в ПО, заносим новый 
баг. 

Задача 2: Программист получает баг, старается понять, в чем про- 
блема, и если это действительно баг, то 


Задача 3: Программист начинает ремонт. 

Задача 4: После того как ремонт закончен, программист 
должен сделать сйескіп кода в С/5. 

Задача 5: Релиз-инженер запускает новый билд, чтобы от- 
ремонтированный код пришел из СУ на тест-ма- 
шину. 

Задача 6: Тестировщик проводит регрессивное тестирова- 
ние, и если починка НЕ удалась, то 


Задача 7: Баг возвращается программисту на но- 
вый ремонт. 


Если же починка удалась, то 
Задача 8: Баг закрывается. СооБуе ту Іоуе, Сооађуе. 


Идем обратно к развилке после задачи 2. Допустим, программист 
не считает, что зарапортованная ситуация является багом. Тогда ОН: 


Задача 9: Возвращает баг. 
Задача 10: Тестировщик старается понять свою ошибку, и 
если ошибка имела место и баг соответственно 
места не имел, то 


Задача 8: Баг закрывается. 


Если же тестировщик считает, что это все-таки баг, то 
баг отправляется обратно программисту. 


Задача 2: Программист снова пытается понять, баг ли это. И т.д. 
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Детальное рассмотрение процесса 


Давайте вольем в рассмотренную форму содержимое, состоящее 
из атрибутов и их значений, как мы хотим это нашей компании 
улууу. ѓеѕіѕћор.т. 


Задача 1: 


Атрибут Комментарий по заполнению либо 
конкретное(ые) значение(я) атрибута 
Реѕсгіріоп апа Зерз Описание и шаги... 
ёо Вергодисе 
Аќасһтепі Используем это поле, если нужна дополнительная 
иллюстрация 


Аѕѕірпеа їо Имя программиста 
Сотропепе Название компонента 


Задача 2: 


Программист признает, что это баг: 


Задача 3: 


Везошоп "Е1х іп Ргоргеѕѕ" 


Задача 4: 


Аѕѕірпеа їо Имя релиз-инженера 


Задача 5: 
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и после того, как НОВЫЙ билд появился на тест-машине: 


Аѕѕірпеа #0 Имя лица из Ге’ йег 


Задача 6: 


Баг НЕ починен: 


Задача 7: 


ВезоаНоп "Уегіћсайоп ЕаПеа" 


Баг починен: 


Задача 8: 


Обратно к задаче 2: 


Программист НЕ признает, что это баг: 


Задача 9: 


ВезоаНоп "Сап Кергодисе", либо 
"БирПсае", либо "Мої а 
бир", либо "Зга раму 
Бао", либо "Мо Іопоег 
аррНсаЫе" 


Задача 10: 


Ба 


Г; 


НЕ баг: 


Конкретный пример 


Тестировщик Антон Никонов при исполнении тест-кейса ЯМВЗТО001 
обнаружил новый баг. Он открывает СТБ и заносит в нее нового 
жителя: 
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Атрибут: биттагу. 

Значение: 
"Спек. 1211: неверное значение колонки тезий таблицы 
сс іғапѕасйоп для ҮІЅА ". 


Атрибут: Резсёрйоп апа ѕїерѕ 10 герго4исе. 
Значение: 
"Резсирноп: 


При оплате картой ИІЅА в колонке гезий таблицы 

сс іғапѕасіоп в базе данных записывается неверное значение. 
Используйте следующую информацию для воспроизведения 
проблемы: 


Эккаунт: 4еяизег Гра $ Ога 

Наименование товара: Боок117 
Данные карты: 

Номер: 9999-5148-2222-1277 

Окончание действия: 12/07 

СҮҮ2: 778 

501.1: ѕеіесі гезий гот сс іғапѕасіоп ийеге А — <номер 
заказа>; 


51ерѕ іо гергодисе: 


1 Открой ууу. таіп.іеѕіѕћор. ғ. 
2. Введи имя пользователя. 
3. Введи пароль. 
4 Нажми кнопку "Войти ". 
5. Введи наименование товара в поле поиска. 
б Нажми кнопку "Найти ". 
7. Кликни линк "Добавить в корзину ". 
8 Кликни линк "Корзина". 
9 Кликни линк "Оплатить". 
10. Выбери вид карты. 
11. Введи номер карты. 
12. Введи срок окончания действия. 
13. Введи СУУ2. 
14. Нажми кнопку "Завершить заказ". 
15, Запиши номер заказа. 
16. Запроси базу данных с ЗОШ. 


Вие: 20. 
Ехресеа: 10". 
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Атрибут: 45ѕіопей 10. 
Мистер Никонофф идет на страничку в интранете "Кто ответст- 
вен за что" и видит, что программистом Оплаты в настоящее 
время является О. Столяров. Так и запишем. Значение: 

"О. Столяров". 


Атрибут: Сотропет 
Значение: "Оплата ". 


Атрибут: Ғоина оп. 
Баг был найден при тестировании на ууу. таіп. іеѕіѕћор. г. 
Значение: 

"уруру таїп.іехіѕћор. ғ". 


Атрибут: Гегуюп Еоина. 

Антон знает, что номер версии и номер билда видны в коммента- 
риях НТМІ.-кода на всех страницах нашего веб-сайта. Поэтому он 
открывает в окне браузера ууу. гтаіл.іеѕіѕћор.тѕ, делает клик пра- 
вой кнопкой мышки и выбирает ИЙем Раве боигсе (посмотреть 
код страницы). Запускается текстовый редактор, например № 1е- 
раа (Блокнот), в котором виден НТМГ-код страницы, и в коммен- 
тариях Антон находит номер версии и номер билда, например 
7.0-58. Значение: "7.0". 


Атрибут: Вийа Еоипа. 
Значение: 
"55 15 


Атрибут: $еуегйу. 
Это обычный функциональный баг, четко подходящий под СЗ. 
Значение: 

"С5 " 


Атрибут: Риогйу. 

Мы должны понять, какие будут последствия в случае если зна- 
чение колонки гезий таблицы сс іғапѕасііоп не равно 10 при оп- 
лате карточкой /18А4. Мы задаем вопрос программисту, и выясня- 
ется, что в этом случае на машине для пользователей транзакция 
будет считаться недействительной, даже если деньги с карточ- 
ку будут сняты и соответственно пользователь не получит своего 
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заказа. Довольно серьезный баг, если учесть, что /154 — это наи- 

более широко используемая платежная система. Исходя из 

вышесказанного, мы должны дать багу приоритет ПТ. Значение: 
"Я 7 Ш 


Атрибут: №йўу Ії51. 
Согласно странице интранета "Кто ответствен за что", оплата ку- 
рируется продюсером В. Новоселовым. Значение: 

"5. Новоселов". 


Атрибут: Туре. 
Значение: "Вис". 


Атрибут: Ќеѕоіийоп. 
Мы знаем имя программиста, который должен заняться багом, и 
поэтому ставим резолюцию как "А51епей". Значение: "Аѕѕіспеа". 


СТБ присвоила багу номер 3221. 


После того как баг был занесен, е-мейлы летят к 


• А. Никонову (Зибтиеа Бу — автор бага), 
О. Столярову (А551епей іо — держатель бага) и 
• В.Новоселову (лицо из № ой}? 15%. 


Поскольку держателем бага стал Олег Столяров, то за ним и сле- 
дующее действие, а именно рассмотрение проблемы. 


Проблема рассмотрена, и баг найден в коде Руйоп файла 
сгеаіе раутепі.ру: 


Исге4й саға== "ИА": 


ираше _АБ(" ираше сс іғапѕасйоп ѕеі гезий = 20 ийеге ехіег- 
па! іа = " + іғапѕасйоп 14). 


Этот код, переведенный на язык Пушкина и Булгакова, означает: 


Если используется кредитная карта ИА, 
сделай значение колонки тезий таблицы сс_тапзасйоп рав- 
ным 20 в строке, где значение колонки емегпайА равно 
значению переменной іғапѕасіопій. 
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Как видим, это простой в починке баг, который исправляется из- 
менением цифры 2 на цифру 1: 


і стейИ сага == "ҮІЅА ": 
ирааіе ађ("ирааіе сс іғапѕасійоп ѕеї гезий — 10 ућеге ехіег- 
па! 14 - "+ тапз аспоп 14). 


Олежек входит в СТБ: 


Атрибут: Ќеѕоіийоп. 
Значение: 
"Еіх т Ргоотеѕѕ ". 


Олежек исправляет баг на своем плэйграунде, делает скоренький 
юнит-тест и сохраняет баг в бранче СУ$ для релиза 7.0 и в стволе. 


Затем он снова входит в СТБ и передает баг дальше: 


Атрибут: Везоийон. 
Значение: 
"Еіхеа". 


Атрибут: Гегуюп Ехей. 
Значение: 
7. 0 и 


Атрибут: Вийа Ехеа. 
Значение: 
"59 2А 


Сегодня вторник, а значит, согласно страничке в интранете "Рас- 
писание релиз-инженеров", новый билд может запустить для нас 
релиз-инженер С. Щетинин, который сегодня находится на де- 
журстве по всем вопросам, связанным с багами. 


Атрибут: 45ѕіопей 10. 
Значение: 
"С. Щетинин". 


С. Щетинин, только что вернувшийся с обильного обеда, про- 
шедшего в ресторане "Маујоуег" в окружении институтских 
дружков, таких же, как он, тунеядцев и игроков в покер, получает 
от СТБ е-мейл о том, что он стал новым держателем бага #3221. 


С. Щетинин является держателем и множества других багов, 
ждущих своего регрессивного тестирования. Согласно распи- 
санию билдов в компании ууу. ѓеѕіѕйор. г, у нас есть 3 билда 
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в день: в 12:00, 15:00, 18:00 по московскому времени. Сейчас 14:45, 
и через 15 минут Станислав должен запустить новый очередной 
билд (59) для версии 7.0. 


Запустив билд-скрипт для версии 7.0, он входит в СТБ и среди 
прочих меняет и #3221: 


Атрибут: Везоийон. 
Значение: 
"ВиНА т Ргоетеяу ". 


После того как билд-тест сайта ууу. таїп.іеѕіѕһор.тѕ завершен и не 
было никаких ошибок (например, проблем с интеграцией кода одного 
программиста с кодом другого), сеньор Щетинин снова идет в СТБ: 


Атрибут: Везоийон. 
Значение: 
т Ге}? 4и 


Атрибут: 455іопей 10. 
Значение: 
"А. Никонов". 


Если ошибки поломали билд, то начинается выяснение и устра- 
нение. Ошибка может быть допущена как релиз-инженером, так 
и программистом. В последнем случае срочно посылают е-мейлы 
программистам с целью выяснить, чем код поломал билд, чтобы 
те немедленно разобрались, в чем дело. Если проблема сломан- 
ного билда (Фгокеп Бийа) не решается в течение, скажем, 60 ми- 
нут, то, согласно правилам нашей компании, С. Щетинин воз- 
вращает на му. таїп.іеѕіѕћор.гѕ предыдущий билд, т.е. 58. 


Тестировщик Антон Никонов получает радостное известие, что 
баг #3221 был зафиксирован и отремонтированный код ждет его 
на уруу. таїп.іеѕіѕћор.тѕ. У достоверившись, что ууу. таїп. іеѕіѕћор. г 
имеет версию и билд 7.0-59, он исполняет шаги, указанные в 
"Описании и шагах..." бага, и, удостоверившись, что значение 
гезий стало равным 10, закрывает баг: 


Атрибут: Ќеѕоіийоп. 
Значение: 
"Рах 15 Уегіһеа". 


Атрибут: 55. 
Значение: "С/оѕей". 
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А затем в качестве второй части регрессивного тестирования ис- 
полняет, например, тест-кейс с картой МаяегСагта. Флоу с 
МаяегСага — это приоритетное флоу функциональности Оплата, 
и неплохая идея проверить, что ремонт ситуации с ИГА не сломал 
флоу с МаѕіегСага. 


Краткое подведение итогов 


1. 


СТБ —это 


• содной стороны, хранилище багов, а 
• с другой — средство коммуникации. 


Баг — это в зависимости от контекста 


• расхождение между фактическим и ожидаемым результатами 
и/или 
• запись (виртуальная карточка) в СТБ. 


Настройки СТБ определяются процессом, а не наоборот. 
Настройками СТБ и созданием эккаунтов ведает администратор 
СТБ. 

Занести баг может любой, у кого есть счет в СТБ и соответст- 
вующая привилегия. 

У бага в СТБ есть атрибуты, значения которых позволяют судить 
о состоянии и истории бага. 

Значения некоторых атрибутов присваиваются автоматически 
(номер бага). 

Мы никогда не заносим баг с кратким описанием "Ничего не 
работает". 

Приложение (аїќасһтепі) — это суперполезная вещь, так как 
служит графической (как правило) иллюстрацией бага. 


У каждого открытого бага всегда есть держатель. 


. На интранете обязательно должна быть страничка "Кто ответ- 


ственен за что". 

Серьезность бага —это техническая категория. 

Приоритет бага — категория, связанная с бизнесом. 

Нет ни одного изменения бага, которое бы не стало достоянием 
гласности. 

Функциональность — это только одно из значений емкого тер- 
мина фича. 

Значения резолюции — это этапы жизни бага. 


Вопросы и задания для самопроверки 


1. 


2. 


Могут ли простые бумажные карточки или текстовый файл слу- 
жить в качестве СТБ? 

Приведите пример формата значения атрибута "Шаги и ожи- 
даемый результат". 
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. Чем били по голове тех, кто заносил баг с кратким описанием 


"Ничего не работает"? 

Перечислите элементы веб-страницы и проблемы, с ними свя- 
занные. 

Как сделать графический файл с тем, что мы видим на экране 
монитора? 

Основная обязанность держателя бага. 


. Что должен проверить Мепйег перед началом регрессивного 


тестирования? 

Приведите две части регрессивного тестирования. Нужно ли 
проводить вторую часть, если первая не работает? Можно ли 
закрыть баг уже после первой части, если ремонт был успешен? 
В чем концептуальное различие серьезности и приоритета? 


. Кого мы обычно включаем в №оШу 15Е? 
. Дайте определение фича. 
. Почему возникают ситуации, когда баги приходится открывать 


заново? 


. Что нужно делать для того, чтобы программисты не возвращали 


вам баги как "Моѓ Рергоаисібіе""? 


я Почему возникают ситуации, когда баг возвращается с резо- 


люцией "Моѓ а рид"? 


. Нарисуйте блок-схему процесса трэкинга багов. 


ИСПОЛНЕНИЕ ТЕСТИРОВАНИЯ. 
СТАДИЯ 1: 
ТЕСТИРОВАНИЕ НОВЫХ ФИЧА 


• ТЕЗТ ЕЗИМАТЮМ (ТЕСТ-СМЕТА) 
• ЕМТВУЕХП СВІТЕВІА (КРИТЕРИЙ НАЧАЛА/ЗАВЕРШЕНИЯ) 
• ТЕЗТРЕАМ (ТЕСТ-ПЛАН) 


х при разговоре о процессе разработки ПО мы перевели 
"Меж Ееаіиге Тезйпе" как "Тестирование новых компонен- 
тов", я предлагаю немедленно заменить "компонентов" на "фича", 
так как это более точный перевод и мы уже знаем, что такое фича. 


Исполнение тестирования состоит из двух стадий, идущих в сле- 
дующей очередности: 


1. Тестирование новых фича (леу /еаѓиге іеѕійпуе); 
2. Регрессивное тестирование (7еогеѕѕіоп 1е5 Пиз). 


Сначала о стадии 1. 


После того как код проинтегрирован, тест приемки пройден И КОД 
заморожен, мы начинаем тестирование новых фича. 


Кстати, тест приемки — это, как правило, эд хок-тестирование, при ко- 
тором мы проверяем, работают ли самые базовые вещи, как, например, 
создание нового эккаунта. Я рекомендую составить список с такими 
базовыми вещами, например: 

Создай новый эккаунт 

Войди в систему 

Добавь книгу в корзину... и во время теста приемки мы просто идем 
от строчки к строчке и делаем проверку. Тест приемки считается 
пройденным, когда каждый из наших мини-тестов имеет положительный 
исход. 
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— Как несвоевременно! 
Как несвоевременно и коварно 
был исполнен его тест-кейс! 
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Кстати, хорошая традиция — это устроить в конце подготовки к тести- 
рованию (или начале исполнения тестирования) совещание, на кото- 
ром каждый тестировщик, у которого есть новая фича, сделал бы ее 
короткую, например на две минуты, презентацию. Таким образом мы 
быстро и эффективно распространяем информацию о новых фича, так, 
чтобы все были в курсе. 


Вопрос: Как мы тестируем новые фича? 

Ответ: Все очень просто: берем в зубы тест-кейсы и исполняем 
их. Попутно заносим баги. Спорим с программистами о приори- 
тетах этих багов. Закрываем эти баги. Одним словом, обычная 
суета сует. 


Это в общем-то все насчет стадии 1 исполнения тестирования, но, 
поскольку нужно чем-то занять время, давайте поговорим о не- 
скольких нужных вещах: 


• Тез Езитайопн (тест-смета). 
. Епну/Ехи Сиена (критерий начала/завершения). 
• Тез Рап (тест-план). 


Тез Еѕіїтайоп (тест-смета) 


Как правило, в интернет-компаниях существует расписание рели- 
зов. К этому расписанию привязано расписание тестирования (ОА 
5срейше), которое определяет сроки каждой стадии процесса тес- 
тирования. 


"Как правило" было употреблено из-за того, что в некоторых 
компаниях такого понятия, как "Расписание", не существует в 
принципе. 


Итак, допустим, что 


• на подготовку к тестированию дается две недели (10 ра- 
бочих дней (80 часов) + 4 выходных дня (32 часа), которые 
элементарно могут стать рабочими); 

• на исполнение тестирования также дается две недели 
(10 рабочих дней (80 часов) + 4 дня выходных дня (32 часа), 
которые также элементарно могут стать рабочими), 


т.е. у нас есть 


две недели на написание тест-кейсов (и прочие подготови- 
тельные мероприятия) и 
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две недели, в которые нужно уместить: 


• тестирование новых фича по созданным тест-кейсам; 
• регрессивное тестирование. 


Проблема в том, что, как бы ударно мы ни работали, мы можем 
выполнить лишь определенный объем работы и возникает кон- 
фликт между 


• лавиной новых фича, которые могут понадобиться ДЛЯ биз- 
неса компании, и 

® физическими возможностями продюсера, программиста и 
тестировщика. 


Чтобы уравновесить желаемое и реальное, используют еметы 
(еѕіітаійоп). 


Тестировщик готовит тест-смету (Тез! Езйтайоп), которая вклю- 
чает: 


• предварительную оценку времени, необходимого на под- 
готовку к тестированию; 

• предварительную оценку времени, необходимого на тести- 
рование новых фича. 


Как тестировщик готовит тест-смету? Очень просто: 


после того как написан спек, менеджер тестировщика просит по- 
следнего прочитать этот спек и оценить, сколько времени займут 
написание тест-кейсов по этому спеку и прочие подготовитель- 
ные мероприятия и исполнение этих тест-кейсов. Тестировщик 
читает спек, предметно общается с продюсером и программистом 
и на основе полученной информации и своего опыта предостав- 
ляет менеджеру два числа, являющиеся тест-сметой для данного 
спека. 


Пример 

Для создания тест-сметы тестировщику был дан спек #1299 "Новые 
функциональности поиска". 

Тестировщик предоставил своему менеджеру следующее: 


• потребуется 50 часов на написание тест-кейсов и 20 часов на 
написание тест-тулов; 
• потребуется 60 часов на исполнение этих тест-кейсов. 


Таким образом, тестировщик полностью укладывается в график по 
подготовке к тестированию (80 - 50-20 >0). Оставшиеся 10 часов 
можно будет использовать для помощи своим коллегам и/или как ре- 
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зерв на случай, если оценка тестировщика была неверной и на подго- 
товку в реальности потребуется больше времени. 


Сложнее обстоит дело с исполнением тестирования. На регрессивное 
тестирование остается только 20 часов (80 - 60). Будет ли этих 20 ча- 
сов достаточно, чтобы закончить регрессивное тестирование в срок? 
Это зависит от нескольких факторов, основные из них: 


• значительность релиза, например: имело ли место серьезное 
изменение архитектуры ПО? На сколько процентов изменилось 
количество строк кода? Были ли добавлены новые критические 
функциональности, интегрированные со старым кодом? и пр.; 

• трудоемкость тест-комплектов, которые нужно исполнить для 
регрессивного тестирования (подробно поговорим о нюансах 
регрессивного тестирования через полчаса). 


Ответ на последний вопрос ("будет ли достаточно 20 часов?"), как и 
сам процесс уравновешивания потребностей бизнеса и возможностей 
работников, — это епархия менеджмента, а мы люди простые, и наше 
дело — дать предварительные оценки, по возможности приближенные 
к недалекой реальности. 


Итак, как создать тест-смету? 


Сложность заключается в том, что тест-смета создается после 
того, как прочитан спек, а между чтением спека и работой по не- 
му такая же дистанция, как между теоретиком и практиком кун- 
фу. Во время работы над спеком, т.е. создания по нему тест- 
кейсов, открываются такие грани и нюансы, о существовании ко- 
торых было трудно (если не невозможно) предположить во время 
простого прочтения. Кроме того, всегда есть непредвиденные 
обстоятельства, среди которых может быть, например, неприлич- 
но большое количество блокирующих багов. 


Кстати 
после того как тест-смета готова, рекомендую увеличить ее на 10%, 
чтобы учесть такие непредвиденные обстоятельства. 


Вот факторы, которые я рекомендую принять во внимание при 
составлении сметы: 


• предполагаемая сложность новых фича. 
Чем они сложнее, тем больше нюансов всплывет при под- 
готовке и исполнении и тем больше времени понадобится 
на тестирование; 


• есть ли у вас опыт тестирования похожих фича. 
Например, если вы эксперт в тестировании оплаты, то для 
вас будет проще и быстрее протестировать добавление 
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еще одного вида кредитной карточки по сравнению с 
тестировщиком, который никогда кредитных карточек не 
касался, 


опыт работы на прошлых проектах с теми же продюсе 
ром и программистом. 

Например, одни программисты пишут удивительно чистый 
код, всегда проводят юнит-тестирование и с охотой 
кооперируются с тестировщиками. Другие же бросают 
куски кода в проект, как грязь на стену, считают юнит- 
тестирование вещью, не подобающей для компьютерного 
гения, и не склонны кооперироваться ни с кем, кроме 
виртуальных солдат игры На. Следовательно, во втором 
случае мы должны заложить больше времени на наше тес- 
тирование; 


будет ли интеграция нашего ПО с ПО наших бизнес-парт 
неров — вендоров (уепдог), 

например интеграция с ПО платежной системы. Тест-кон- 
фигурация выглядит так: наша тест-машина "разговари- 
вает" с их тест-машиной. Соответственно если что-то не в 
порядке с их тест-машиной, то проблема решается слож- 
нее, чем при локальном тестировании, когда вы заносите 
баг и наш программист его ремонтирует. В случае с их 
тест-машиной 


• тестировщик связывается с менеджером проекта (с на- 
шей стороны); 

• последний должен позвонить вендору; 

• человек со стороны вендора должен найти ответст- 
венного программиста; 

• ответственный программист может быть занят 

• ИТД. ИТ.П. 


В общем целая петрушка из-за того, что это другая ком- 
пания и наши тестировщики не указ "их" программистам. 
В случае с интеграцией нашего ПО с не нашим ПО оценка 
должна принимать в расчет подобные задержки в решении 
проблем, которые при такой интеграции бывают всегда; 


нужны ли тулы для автоматизации тест-кейсов? 
Тест-тулы, как правило, создаются во время написания тест- 
кейсов как средство для облегчения исполнения тест-кейса, 
например: 
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• генерация данных (например, генерация номера тес- 
тировочной кредитной карты), 

• автоматизация всех либо части шагов, 

• помощь в сравнении фактического и ожидаемого ре- 
зультатов. 


В одних случаях тестировщик может сам написать такой 
тул, например, на языках Јауа или Руйоп. В других 
случаях написание тула в помощь тестировщи-кам — это 
дело программиста. 


Кстати 
в некоторых компаниях внутри департамента качества существую! 
специальные отделы по созданию тест-тулов. 


Вы должны подкорректировать тест-смету в зависимости от ва- 
шей оценки того: 


• сколько времени у вас займет создание (включая тестиро- 
вание) такого тула (если тул создается вами, а не програм- 
мистом); 

• сколько времени этот тул сможет реально сэкономить во 
время тестирования новых фича. 


Итак, при составлении тест-сметы используем вышеперечислен- 
ные факторы, слушаем свои опыт и интуицию и советуемся с 
коллегами. 


Упоминание о тест-тулах напомнило мне об одном предмете, который 


особенно беспокоит сердца обучающихся тестированию, а именно 
объеме компьютерных знаний. 


Вот мое мнение: естественно, что наивно думать об устройстве тес- 
тировщиком в интернет-компанию тому, кто не умеет пользоваться 


е-мейлом и веб-браузером и не знает разницы между принтером и 
модемом. 

Хорошая новость: на первую работу тестировщиком можно устроить- 
ся, имея базовые компьютерные знания, которые есть у каждого, кто 
пользовался компьютером и Интернетом больше одного месяца. 
Конечно, шансы трудоустройства существенно повышаются, если 


у вас есть дополнительные к базовым знания (приведу конкретные 
рекомендации через минуту). 


Давайте скажем "Спасибо" океану информации под названием "Ин- 
тернет" за 
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гигабайты бесплатного ПО, например компайлеры для С++ и 


интерпретаторы Руѓћоп; 
тысячи бесплатных курсов по компьютерным дисциплинам, на- 
пример пособия по изучению языка $01; 
интернет-форумы на любую тематику, где любой оболтус (вклю- 
чая меня) может задать самый идиотский вопрос и получить 
на него ответ; 
веб-сайты, бродя по которым мы попутно становимся квалифи- 
цированными пользователями Интернета; 

• десятки других милых и полезных вещей. 


Используйте ресурсы Интернета!!! В нем есть все, что вам нужно, что- 
бы стать тестировщиком экстра-класса. 

Вот список вещей, к которым я предлагаю хотя бы прикоснуться 
перед поиском первой работы. Потратьте по крайней мере по 10 ча- 


сов на каждое "прикосновение", причем не просто читайте теорию, 
а работайте с соответствующим ПО (или на соответствующем ПО), 


например: 
• в случае с ИМИ исполняйте команды, например команду "таг", 
для создания директории или 
• пишите код на РуПоп. 
НТМЕ. Основной язык веб-страниц. Веб-учебник (иер ѓиѓогіа) 
на английском языке и программа для симуляции может быть 
найдена здесь: Ийр://миим.м3Ззспоо5.сот. Изучите базовые теги 
({а9). 
801. Язык баз данных. Веб-учебник на английском языке можно 
найти здесь: ћіір://уууи/.ммЗѕсһоо!іѕ.сот. Разберитесь с синтакси- 
сом следующих видов запросов (5{аетеп{5): 
СКЕАТЕ ТАВІЕ; 
АІТЕЋ ТАВІЕ; 
ОКОР ТАВІЕ; 
ІМЅЕКТ 1МТО; 
ОРРАТЕ; 
РЕІЕТЕ; 
ЅЕІЕСТ. 
Скачайте и установите на ваш компьютер базу данных Му$ОЁ 


(ір://мљму.туѕд1.сот/). 
Рупоп. Веб-учебники на английском языке и установочную про- 


грамму для интерпретатора можно найти на ИЁр://Лммии.ру{оп.огд. 
Возьмите самый простой учебник и ощутите всю прелесть просто- 
ты и доступности моего любимого языка программирования. 


ОМІХ. Вот наипростейший веб-учебник: 


ВЕ р:/ммим. таїћ.иќаһ.едиЛаһ/ипіх/ипіх-ішіогіа1.һіті. Симулятор УМХ 
для Виндоуз-машин можно скачать здесь: ћіёр://уи.судиіп.сот. 
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5. С++. Веб-учебник может быть найден здесь: 


ћір:/№м№м.сріиѕріиѕ.сот/аосЛиіога!. Напишите несколько про- 
грамм, скомпилируйте их, откройте в текстовом редакторе файлы- 
источники (ѕоигсе їе), скомпилированные файлы (Буесоае ЙЕ) 
и ощутите разницу. Компайлер дсс является частью симулятора 
СудИ/т, которую вы установите при знакомстве с УМХ. 


Естественно, что мои пояснения о том, ЧТО изучить для каждого из 


вышеуказанных 5 предметов, — это минимум для того, чтобы иметь 
элементарное представление, но даже такой минимум — это ваш ко- 
зырь. Очень рекомендую. То, что сейчас кажется вам сложным и запу- 
танным, будет доступным и понятным завтра. Нужно только иметь 
терпение и приложить немного усилий. 

После того как вы найдете работу, специфика ваших технических зна- 
ний будет во многом определяться технологиями, используемыми в 
вашей интернет-компании (например, операционная система маши- 
ны для пользователей, языки программирования, вид базы данных). 
Некоторые из тех, кто начал работать тестировщиком на черноящич- 
ном тестировании, распробовали знания из смежных специальностей 
(например, администрация баз данных) и переместились туда; 
некоторые выбрали себе узкую специализацию внутри департамента 
качества, например написание тест-тулов; 

некоторые продолжают с удовольствием для себя и пользователей 
заниматься черноящичным тестированием или же перешли к серо- 
ящичным или белоящичным делам — кчему лежит душа. 

Но чтобы найти в итоге свою нишу, нужно искать, а лучший по- 
иск — это изучение новых вещей. 

Одна из прелестей нашей профессии заключается в том, что 


тестировщик соприкасается с множеством вещей как техниче- 
ского (язык программирования), так и нетехнического свойства 
(менеджмент проекта), так что вам и карты в руки — разбери- 
тесь на месте, что вам больше нравится, и приложите усилия, 
чтобы в итоге заниматься именно этим. Шансы велики, что это 
будет именно тестирование. 


Епігу/Ехіє Степа 
(критерий начала/завершения) 


Все очень просто. 


Етту Стйета (условие старта) — это условие для начала чего- 
либо. 

Ехи Сүійегіа (условие завершения) — это условие для завершения 
чего-либо. 
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Каждый из двух этапов тестирования имеет свои условия старта и 
условия завершения. 


Например 

Условие старта для подготовки к тестированию: все спеки должны быть 
заморожены. 

Условие завершения подготовки к тестированию: тест-кейсы и прочие 
подготовительные мероприятия написаны и закончены. 

Условие старта для исполнения тестирования: код заморожен. 

Условие завершения исполнения тестирования: тестирование новых 
функциональностей и регрессивное тестирование завершено, нет от- 
крытых П1 и П2 багов. 


Тез Р!ап (тест-план) 


Вопрос: Почему мы не поговорили о тест-планах при нашей бе- 
седе о тест-кейсах и тест-комплектах? Ответ: Я не хотел 
забивать вам головы. 


Вопрос: Тогда почему вы их забиваете сейчас? 
Ответ: Потому что с теми знаниями, которые у вас уже есть, вам 
будет проще понять этот материал. 


Итак, приступим. 


Что такое тест-план? Если вы спросите тестировщиков разных 
компаний о том, что идет под именем "тест-план" в их компа- 
ниях, то ответ часто будет варьироваться: 


иногда тест-планом называют тест-комплект, 

в других случаях тест-планом называют пару мыслей о тес- 
тировании, набросанных на полях журнала "Р/аубоу", 

в третьих случаях тест-планом называют текстовый доку- 
мент, содержащий выдержки из спека, глядя на которые и 
проводится тестирование (такое тоже бывает сплошь и рядом), 
есть еще и четвертые, и пятые случаи. 


Вот концептуальная вещь: 


тест-кейс нужен для сравнения фактического результа- 
та с ожидаемым результатом; 

тест-комплект — это логическая оболочка для хране- 
ния тест-кейсов; 

тест-план — это документ, обобщающий и координи- 
рующий тестирование. 
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Я обычно ограничиваюсь тест-комплектами и создаю тест-план, 
если возглавляю проект с участием других тестировщиков. 


Давайте рассмотрим элементы, которые вы можете использовать 
в тест-планах. 


Кстати, вовсе не обязательно использовать все элементы: 


1. Вы можете взять элементы (и/или идеи из них) и интегрировать их 
в свои тест-комплекты; 
2. Вы можете использовать тест-план в усеченном виде. 


Итак... 


ЭЛЕМЕНТЫ ТЕСТ-ПЛАНА 


1. Название тест-плана, имя автора и номер версии. 


Например 


«Тест-план проекта "Новые алгоритмы для поиска"». Автор Т. Чере- 
мушкин. Версия 2. 


2. Оглавление с разделами тест-плана: 


Например 

Введение стр. 2 
Документация с требованиями к ПО стр. Зи 
т. д. 


3. Введение, в котором мы приводим информацию о сути и исто- 
рии тестируемого проекта. 


4. Документация с требованиями к ПО — здесь мы перечис- 
ляем имена, номера и приоритеты спеков и/или другой докумен- 
тации, определяющей тестируемые фича. 


5. Фича, которые будут тестироваться, перечисляем и, если 
нужно, комментируем. Каждой фича назначается приоритет. 


6. Фича, которые НЕ будут тестироваться, перечисляем и объ- 
ясняем, почему НЕ будут тестироваться. 


Например, 


частью спека #9172 "Упучшение безопасности платежных транзакций" 
являются требования к скорости работы веб-сайта (ретогтапсе). До- 
пустим, у нас нет ни специалиста, ни ПО для тестирования скорости 
работы, и если мы не собираемся их нанять и приобрести, то указываем, 
что перформанс тестироваться не будет, так как нет ресурсов. 
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7. Объем тестирования — виды тестирования, которые мы бу- 
дем проводить, и разъяснения к ним. 


Например 


"Системное тестирование будет исполняться для проверки всего флоу 
оплаты, начиная от добавления книги в корзину и заканчивая про- 
веркой значений базы данных и подтверждением от тест-машины 
вендора". 


8. Тест-документация —Щ перечисление тест-документации, ко- 
торая должна быть создана для данного проекта 


Например 


"Тест-комплект по тестированию опека #1288. 
Тест-комплект по тестированию спека #3411". 


9. Тест-тулы — функциональности тест-тулов, которые должны 
быть созданы для тестирования проекта. 


10. Критерий начала/завершения — те самые критерии, о кото 
рых мы говорили минуту назад: 


ы критерий начала подготовки к тестированию; 

е критерий завершения подготовки к тестированию; 
а критерий начала исполнения тестирования; 

Ы критерий завершения исполнения тестирования. 


11. Допущения — список допущений, которые мы сделали при 
составлении данного тест-плана и которые сделаем при тестиро 
вании. 


Например, 


мы допускаем (предполагаем), что код будет заморожен в срок, без 
задержки. 


12. Зависимости — список вещей (с пояснениями), от которых 
зависит та или иная часть тестирования. 


Например, 


покупка новых тест-машин, 
лицензия на осуществление платежных операций на территории Вели- 
кобритании. 


13. "Железо" и ПО — список и конфигурации "железа" и ПО, 
которые будут использоваться при тестировании. 
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14. Условия приостановки/возобновления тестирования — это 
условия, при которых тестирование должно быть остановлено/ 
продолжено. 


Например, 


к условию приостановки можно отнести количество П1 багов, при ко- 
тором (шили после которого), по мнению автора (-ров) тест-плана, 
дальнейшее продолжение тестирования не имеет смысла (например, 
7 П1). Соответственно условием возобновления должно быть количе- 
ство оставшихся П1 багов (после ремонта и регрессивного тестирова- 
ния), которое позволяет возобновить тестирование (например, 2 П1). 


15. Ответственные лица — подробный список товарищей (про- 
дюсеров, программистов, тестировщиков и пр.), контактная ин- 
формация и обязанности каждого из них. Такой список может 
включать лиц со стороны вендора. 


16. Тренинг — тренинг, необходимый для данного проекта. 


Например, 


при соответствующей ситуации нужно указать, что для создания тест- 
кейсов тестировщику необходимо прослушать семинар "Банковская 
система США". 


17. Расписание — сроки, имеющие отношение к тестированию 
данного проекта: 


• дата замораживания спеков; 

• дата начала подготовки к тестированию; 

• дата завершения подготовки к тестированию; 
• дата интеграции и замораживания кода; 

• дата начала тестирования новых фича; 

• дата завершения тестирования новых фича; 

• дата начала регрессивного тестирования; 

• дата завершения регрессивного тестирования. 


18. Оценка риска — предположение о том, как и что может пой 
ти по неправильному пути и что мы в этом случае предпримем. 


Например, 


если мы не успеваем закончить тестирование (не выполняем требова- 
ние "Условия завершения", например, "все тест-кейсы исполнены") в 
срок, то придется задерживаться на работе и приходить в офис в вы- 
ходные и праздники. 


Кстати, если народ приходит в выходные и праздники, то компания 
должна, по крайней мере, кормить его обедом. 
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19. Прочие положения — вещи, не вошедшие в тест-план, о ко- 
торых неплохо было бы упомянуть. 


20. Утверждения — это подписи лиц, которые утвердили тест- 
план. Чем больше будет таких подписей, тем лучше. По крайней 
мере, нужны подписи менеджера тестировщика, составившего 
план, самого тестировщика, продюсера и программиста. 


21. Приложения — например, расшифровка терминов и аббре- 
виатур, используемых в тест-плане. 


Это все о тест-планах и о первой стадии исполнения тестирова- 
НИЯ. 


ИСПОЛНЕНИЕ ТЕСТИРОВАНИЯ. 


СТАДИЯ 2: 
РЕГРЕССИВНОЕ ТЕСТИРОВАНИЕ 


• ВЫБОР ТЕСТ-КОМПЛЕКТОВ ДЛЯ РЕГРЕССИВНОГО 
ТЕСТИРОВАНИЯ 
• РЕШЕНИЕ ПРОБЛЕМЫ ПРОТИВОРЕЧИЯ 


р тестирование как второй этап исполнения тес- 
тирования — это проверка того, что изменения, сделан- 
ные в ПО (для того, чтобы мир увидел новые фича), не поло- 
мали старые фича. 


Допустим, у нас есть 5 тест-комплектов с тест-кейсами ДЛЯ НОВЫХ 
фича, а также 21 тест-комплект с тест-кейсами для старых фича. 
Ситуация эта рождает как минимум два вопроса: 


1. Какие из этих 21 тест-комплекта выбрать, чтобы: 


• проверить именно те части ПО, которые могли быть по- 
ломаны? 

• уложиться в срок, выделенный для регрессивного тести- 
рования (например, 5 рабочих дней + два выходных дня, 
которые вполне могут стать рабочими)? 


2. Что делать с регрессивным тестированием дальше, ко 
гда после релиза к 21 тест-комплекту прибавятся еще 5 
(тест-комплекты, которые проверяли новые фича, прим 
кнут к остальным тест-комплектам и станут кандидатами 
для регрессивного тестирования) и еще, скажем, 10 после 
следующего релиза и т.д. (постоянно нарастающий снеж 
ный ком)? 
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Итак, две темы: 


1. Выбор тест-комплектов для регрессивного тестирования. 

2. Решение проблемы противоречия между ограничен- 
ными ресурсами (например, время на регрессивное тес- 
тирование) и перманентно увеличивающимся количест- 
вом тест-комплектов. 


Кстати, как обычно, я излагаю личное видение предмета. В разных 
компаниях поступают по-разному, но, после того как вы поймете, что я 
вам расскажу, вы сможете немедленно адаптировать свои знания к ре- 
альности компании, в которой будете работать. 


Выбор тест-комплектов 
для регрессивного тестирования 


Первый вопрос: "Как узнать, какие части ПО могут быть поломаны?" 


С одной стороны, как мы уже не раз говорили, в сложной системе, 
которой является более или менее серьезный веб-сайт, во многих 
случаях сверхсложно определить, где и как откликнется измене- 
ние кода, с другой — мы все-таки можем предполагать: 


к какой части ПО принадлежат новые фича (например, 
фича из спека #5419 "Новые функциональности для Кор- 
зины" принадлежат к "Корзине") и 

• какие старые фича напрямую зависят от части ПО с 
новыми фича (например, компонент "Оплата" использует 
данные (по ценам книг), которые передаются ей компонен- 
том "Корзины"). 


Решение следующее: 


Первой группой кандидатов для регрессивного тестирования у 
нас будут тест-комплекты, проверяющие часть ПО, к которой 
принадлежат новые фича. 


Например, 


при новых фича для "Корзины" в первую группу идут все тест-комплек- 
ты, непосредственно тестирующие "Корзину". 


Рациональное объяснение: 

если программист напортачил с кодом, то фича, тестируемые тест- 
комплектами первой группы, будут поломаны скорее всего, так 
как являются частью ПО с измененным кодом. 
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Второй группой кандидатов для регрессивного тестирования у 
нас будут тест-комплекты, проверяющие старые фича, которые 
зависят от части ПО с новыми фича. 


Например, 


при новых фича для "Корзины" во вторую группу мы можем отнести 
тест-комплекты, проверяющие "Оплату". 


Рациональное объяснение: 

если даже программист НЕ сломал ничего, есть большая вероят- 
ность того, что код фича, напрямую зависящей от измененной 
части ПО, также нуждается в модификации (о необходимости ко- 
торой и продюсер, и программист могли просто... забыть). 


Например, при изменениях в коде "Корзины" был легитимно (согласно 
спеку) изменен формат куки (соокіе — файл с информацией о вашем 
заказе, хранящийся на вашем компьютере и используемый веб-сер- 
вером). Часть же ПО, которая заведует "Оплатой", не была модифи- 
цирована (или была модифицирована неверно), и она (эта часть ПО) 
просто не понимает новый формат куки, а следовательно, купить книгу 
не представляется возможным. 


Есть и третья группа, к которой мы подберемся чуть позднее. 
Пока же допустим, что группы только две. 


Проиллюстрируем: 


1 #Х81111 


#151222 
#151333 
#152444 
#192555 


#152888 
#152999 


#152777 


Теперь вопрос второй: "Как уложиться в срок, выделенный для 
регрессивного тестирования?" 


Допустим, что у нас есть два тестировщика и неделя времени, т.е. 
80 человеко-часов (112 — с выходными, 336 — без сна и отдыха). 


Вопрос: Сможем ли мы исполнить все 8 тест-комплектов за эти 
80 часов? 
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Ответ: Очевидно, что для этого нужно знать, сколько времени 
занимает исполнение каждого из этих тест-комплектов. 


Вопрос: Как это узнать? 

Ответ: Каждая компания делает по-своему. В одних компаниях 
есть специальные механизмы трэкинга времени, потраченного на 
исполнение каждого из тест-комплектов (иногда даже считается 
время на исполнение каждого тест-кейса), в других после каждо- 
го исполнения тестировщик указывает время исполнения в шапке 
тест-комплекта. В общем разные бывают варианты, но суть в том, 
что необходимо хотя бы примерно знать, сколько времени зани- 
мает исполнение каждого тест-комплекта. 


"Примерно" — потому что исполнение тест-комплекта может 
варьироваться в зависимости, например, от того, кто его испол- 
няет (хотя есть и другие факторы). На практике, особенно в слу- 
чаях со сложными и трудоемкими тест-комплектами, быстрее 
справляется с задачей тот, кто уже однажды исполняв данный 
конкретный тест-комплект. 


Допустим, что мы знаем, сколько времени занимает исполнение 
каждого тест-комплекта. 


Оговорка: 6 реальной жизни исполнение тест-комплектов, как 
правило, занимает гораздо меньше времени, чем в примере ниже, 
но нам нужна наглядность. 


Группа Номер тест-комплекта Время на исполнение 
(в часах) 


Итого, 131 час, что больше запланированных 80, и даже если мы 
будем работать в выходные, то не хватает 19 часов (131 - 112). 
Эти 19 часов могут быть, например, распределены на работу в 
сверхурочное время: примерно 2 часа 40 минут плюс к нашим 
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восьми часам семь раз в неделю (19:7). Кстати, так и поступают 
во многих стартапах. 


Но допустим, что наш ууру. ѓеѕіѕйор.ғ5 не относится к этим мно- 
гим и славится человечным отношением к своим работникам. 


Итак, нам, гуманистам, не хватает 51 часа (131- 80) для исполне- 
ния регрессивного тестирования. Что можно сделать? Среди прочих 
вещей, таких, как заимствование сотрудников из других отделов, 
можно сделать следующее: у нас есть приоритет каждого из тест- 
комплектов. Так давайте же исполним самые приоритетные из них! 


Группа Номер тест-комплекта Время на исполнение Приоритет 
(в 28 


#75111 | 


|| 


| |ә 


ОТО ПОС СИ 
ЕЕ ООО ИЕ 
АОИ ООО ЗИ ОИ 
СИ МОЕ ЗИ ЕИ 
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Если мы исполним тест-комплекты 


• только 1-го приоритета, то регрессивное тестирование возь- 
мет 24 часа (10+ 14); 

• только 1-го и 2-го, то — 55 часов (24 + 12 + 19); 

• только 1,2 и 3-го, то — 96 часов (55 + +5 + 26), это нам не 
подходит. 


Итак, мы исполняем тест-комплекты 1-го и 2-го приоритетов. 
Оставшиеся 25 часов (80 - 55) можно отдать на исполнение, на- 
пример: 
• спека #1222 (15 часов), либо 
• спека #2888 (26 часов), либо 
• исполнить наиболее приоритетные тест-кейсы из обоих этих 
тест-комплектов (самая лучшая идея). 


Концепция, думаю, понятна. 


Кстати, 
определение списка тест-комплектов для регрессивного тестирования — 
это, как правило, прерогатива менеджмента. 
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Теперь о третьей группе. 


Как правило, большая часть тест-комплектов не входит ни в пер- 
вую, ни во вторую группы. Но они тоже нуждаются в регрессив- 
ном тестировании, так как изменение ПО может каким-то обра- 
зом повлиять и на каждую из них, здесь, как говорится, никто не 
застрахован. Для того чтобы затронуть все тест-комплекты, для 
регрессивного тестирования каждого релиза в порядке очереди 
выделяется по несколько тест-комплектов с расчетом, чтобы все 
существующие тест-комплекты были исполнены хотя бы ОДИН 
раз в определенный период, например в полгода. При недостат- 
ке времени для исполнения тест-комплектов из группы К) ре- 
комендую исполнять лишь самые приоритетные тест-кейсы 
каждого тест-комплекта, выбранного для исполнения при регрес- 
сивном тестировании данного релиза. 


Например, если у нас есть 45 тест-комплектов и один релиз в месяц, 
то, если исполнять по 15 тест-комплектов каждый релиз, за З месяца 
можно исполнить их все. 


Решение проблемы противоречия 


Проблема противоречия между ограниченными ресурсами (напри- 
мер, время на регрессивное тестирование) и постоянно растущим 
количеством тест-комплектов решается следующими способами: 


а. Приоритезация тест-комплектов и тест-кейсов. 
б. Оптимизация тест-комплектов. 

в. Наем новых тестировщиков. 

Г. Автоматизация регрессивного тестирования. 


а. О пользе приоритезации мы уже говорили. Странно, НО во МНО 
гих компаниях предпочитают изматывать людей, вместо того 
чтобы приоритезировать тест-комплекты и тест-кейсы и испол 
нять лишь те из них, которые реально важны. 


б. Оптимизация тест-комплектов. Многие старые тест-комплекты 
могут быть оптимизированы в смысле 


• уменьшения количества тест-кейсов и/или 
• упрощения исполнения тест-кейсов. 


Часто имеет смысл пересмотреть, КАК происходит тестирование 
в старых тест-комплектах: может быть, некоторые из тест-кейсов 
уже устарели и/или были написаны тулы для упрощения работы 
некоторых из них и пр. 
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в. Когда денег много, а ума мало, прибегают к массированному 
найму новых тестировщиков, что, конечно, лишь отодвинет реше 
ние проблемы, но не решит ее, так как нельзя бесконечно нани 
мать людей. Я против массированного найма (иногда нанимаются 
десятки!!! тестировщиков в год) и считаю, что интернет-компании 
нужен департамент качества, состоящий из немногочисленной 
группы профессиональных высокооплачиваемых специалистов, 
которые будут решать проблему регрессивного тестирования 
подходами а, биг. 


Г. Автоматизации регрессивного тестирования посвящено мно 
жество монографий. Я же просто введу вас в курс дела. 


Итак, в проекте ууу. іеѕіѕћор.тѕ скопилось, например, 78 тест- 
комплектов, которые нужно как-то исполнять при регрессивном 
тестировании, причем это количество постоянно увеличивает- 
ся. Так как у нас нет спеца по автоматизации тестирования, то 
мы такого спеца нанимаем. Например, это будет г-и Говорков. 
Созывается совещание тестировщиков, и менеджер представ- 
ляет г-на Говоркова в роли, примерно, мессии, который решит 
все наши проблемы с регрессивным тестированием. Когда слово 
предоставляется самому г-ну Говоркову, то его речь сводится к 
следующему: "Ща я вам тут все заавтоматизирую!" Тратится 
несколько тысяч (нередко десятки тысяч) долларов на покупку 
программы для автоматизации тестирования 5ИК Теѕі (произво- 
дитель — компания $есие), и автоматизация начинается. 


Через неделю происходит первая демонстрация: запускается 
автоматический скрипт и начинается магия: 


подпрограмма силк-теста — агент открывает окно браузера, 
вводит имя пользователя и пароль, нажимает на кнопку "Вход ", 
совершает покупку и оплату и сравнивает фактический резуль- 
тат с ожидаемым. Все в полном восторге, ведь очевидно, что 
через пару месяцев все тест-комплекты будут автоматизиро- 
ваны и, вместо того чтобы работать в поте лица в выходные, 
мы просто запускаем в пятницу автоматический скрипт силк- 
теста, а в понедельник видим результат исполнения каждого 
автоматизированного тест-кейса. Одним словом —лепота! 


Однако когда во время регрессивного тестирования следующего ре- 
лиза мы просим г-на Говоркова запустить автоматические скрип- 
ты для тест-комплектов, которые он уже "заавтоматизироват", 
выясняется, что его автоскрипты не работают из-за того, что ин- 
терфейс веб-сайта был в нескольких местах незначительно изменен. 
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Например, в автоскрипте может быть инструкция о нажатии 
кнопки "Вход " на такой-то странице, и если агент, исполняющий 
автоскрипт, не "видит" кнопки с именно таким названием, то 
генерируется ошибка и исполнение тест-кейса прерывается. 


Г-н Говорков, говорит "фигня вопрос ", тратит на починку скрип- 
тов пару недель и в последний день регрессивного тестирования 
его автоскрипты все-таки исполняют пару из 10 автоматизи- 
рованных им тест-комплектов. В следующий релиз все повторя- 
ется заново, и в итоге менеджер решает уволить г-на Говоркова 
и взять на его место обыкновенного черноящичного тестиров- 
щика — будет дешевле и эффективнее. 


Я ничуть не утрирую. Подобные ситуации происходят в боль- 
шинстве случаев после принятия компанией решения об автома- 
тизации регрессивного тестирования. 


Почему так происходит? 


Автоматизация регрессивного тестирования заключается в соз- 
дании целой тестировочной инфраструктуры с библиотеками 
кода, базами данных, системами отчетности и прочими вещами. 
Создание такой инфраструктуры — дело очень и очень непростое. 


Иногда менеджмент, желая получить результат быстро и любой це- 
ной, давит на спеца по автоматизации, и даже если последний добро- 
совестно создает инфраструктуру для автоматизации, то он это дело 
бросает и абы как автоматизирует максимальное количество тест- 
комплектов, для того чтобы менеджмент мог отчитаться перед выше- 
стоящим менеджментом: "За первый квартач 2005 года было авто- 
матизировано 12 тест-комплектов, содержащих 174 тест-кейса". 


Конечно, все эти автоскрипты не будут вскоре функционировать 
без трудоемкой поддержки, но кого это волнует? Начальство до- 
вольно, и, значит, все "Хоккей". 


Но допустим, что менеджмент все понимает и дает карт-бланш 
на создание Инфраструктуры с большой буквы "Ай". 


ПО — это живое существо. Оно постоянно меняется, и авто- 
матизация, связанная с ПО, должна соответственно меняться 
одновременно с ним. Таким образом, только поддержание (тат- 
іепапсе) существующих автоскриптов — задача, требующая боль- 
ших профессиональных усилий, не говоря уже о написании но- 
вых автоскриптов. 
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Я предлагаю очень простой подход к определению эффективно- 
сти автоматизированного регрессивного тестирования. Посмот- 
рите, сколько багов было найдено при автоматизированном тес- 
тировании за все время использования автоскриптов, разделите 
общие затраты на автоматизацию на количество багов — резуль- 
татом будет стоимость нахождения одного бага. Сделайте то же 
вычисление для того же отрезка времени, но для ручного тести- 
рования и сравните. В 90% случаев стоимость бага, найденного 
автоскриптом, будет в несколько раз превышать стоимость бага, 
найденного вручную. И очень большой шанс, что вы подумаете: 
а зачем вообще нужна ТАКАЯ автоматизация?.. 


Кстати, 


так всегда получается, что в процессе автоматизирования находят 
больше багов, чем при исполнении автоматизации. 


Советую также сравнить время, потраченное на автоматизацию 
(и ее поддержку) для некого тест-комплекта, с временем на исполне- 
ние этого же тест-комплекта вручную. Гарантирую, что результаты 
удивят, в смысле неприятно удивят, и не в пользу автоматизации. 


Таким образом, наиважнейшее значение приобретает профессио- 
нализм специалиста по автоматизации. 


Профессионализм такого спеца заключается не только в его про- 
граммистских навыках, но и в том, как четко он представляет: 


• ЧТО автоматизировать и 
КАК автоматизировать. 


ЧТО: 


Лучший кандидат для автоматизации — это тест-кейс для тести- 
рования старой, устоявшейся фича. Автоматизируя его, мы, по 
крайней мере, можем быть уверены, что автоскрипт не нужно 
будет переписывать из-за изменения фича и соответственно из- 
менения тест-кейса к ней. 


Нет более бессмысленной идеи, чем автоматизировать регрес- 
сивное тестирование для фича, которые только что были выпу- 
щены на машину для пользователей. 


Один мой друг сравнивает фича с человеком: если это ребенок, то 
он постоянно меняется; если же он взрослый, то изменений в нем 
намного меньше и сами изменения менее радикальны — сравните 


Исполнение тестирования. Стадия 2: регрессивное тестирование 281 


того же ребенка, когда ему б и 12 лет; и теперь взрослого, когда 
ему 42 и 48 лет. Идея, я думаю, понятна. 


Чем меньше будет изменений в фича, тестирование которой ав- 
томатизировано, тем меньше времени будет затрачено на под- 
держку. Поддержка же порой превращается в кошмар 


» счередой красноглазых бессонных ночей перед монитором, 

• сгорьким пониманием того, что все было сделано непра- 
ВИЛЬНО, И 

• со сладостным искушением все бросить и поехать с Лелей 
в Ялту. 


КАК: 


Это создание инфраструктуры, позволяющей с легкостью и про- 
стотой 

• Поддерживать существующие автоскрипты; 

• создавать новые автоскрипты. 


Инфраструктура автоматизации регрессивного тестирования должна 


• содной стороны, быть образцом программистского мас- 
терства; 

• сдругой — воплощать наиболее эффективные подходы 
к автоматизации, возможные при данном ПО для автома- 
тизации (например, силк-тесте); 

• стретьей — учитывать нюансы технологий именно этой 
интернет-компании. 


В заключение нашего краткого разговора об автоматизации рег- 
рессивного тестирования я хочу открыть вам одну истину: 


Суровая правда жизни заключается в том, что 100%-я авто- 
матизация регрессивного тестирования сколько-нибудь серь- 
езного веб-проекта — это миф. 


Интернет-компании выбрасывают сотни тысяч долларов, чтобы 
убедиться, что это миф. 


Если ваша компания решила заняться автоматизацией рег- 
рессивного тестирования, нужно потратить столько времени, 
сколько нужно, чтобы найти настоящего профессионала, а 
найдя его, дать ему дышать и не ожидать, что 100% тест-ком- 
плектов когда-либо будут автоматизированы. 


Это все о решении основной проблемы регрессивного тестирования. 


282 


Тестирование Дот Ком. Часть 3 


Хорошая идея — это предусмотреть окончание регрессивного 
тестирования за 23 дня До релиза: 


с одной стороны, у нас будет в запасе 2—3 дня, которые мы 
можем использовать для завершения регрессивного тести- 
рования, если наша оценка того, сколько дней оно займет, 
была неверна. 

с другой — эти 2—3 дня можно потратить на тест-сдачи, 
распределив между тестировщиками части ПО. 


А дальше идет релиз... 


Краткое подведение итогов 


1. 


2. 


Тест-смета необходима для приведения к одному знаменателю 
потребностей компании и возможностей тестировщиков. 

Каждый этап тестирования начинается/заканчивается при на- 
ступлении условия начала/завершения. 

Тест-план — это документ, обобщающий и координирующий 
тестирование. 

Приоритезация тест-комплектов и тест-кейсов имеет наиважней- 
шее значение, так как в условиях постоянного дефицита ресурсов 
у нас, как правило, есть время только на проверку главного. 

Из всех способов решения проблемы асинхронизации ресурсов и 
объема регрессивного тестирования наем новых людей самый 
простой и недалекий. 

Лучше хороший черноящичный тестировщик, чем один или боль- 
ше плохих инженеров по автоматизации регрессивного тести- 
рования. 


Вопросы и задания для самопроверки 


1. 
2. 


3. 


Какие факторы стоит принять в расчет при создании тест-сметы? 
Приведите пример условия начала и условия завершения для 
исполнения тестирования. 

Каково концептуальное отличие тест-плана от тест-кейса и тест- 
комплекта? 

На основании чего мы выбираем тест-комплекты первой группы? 
Почему? 

На основании чего мы выбираем тест-комплекты второй группы? 
Почему? 

Что, на ваш взгляд, более приоритетно: тест-комплекты первой 
или второй группы? 

Какие последствия для компании влечет неграмотная автомати- 
зация регрессивного тестирования? 


ЧАСТЬ 4 


. КАК УСТРОИТЬСЯ 
НА ПЕРВУЮ РАБОТУ? 


— Есть ли у вас опыт работы 
Г |] спестицидами? 
— Нет, но если нужно, я все 
\ о них узнаю в мгновение ока. 


/ — Не соврал. 
Действительно: 
в мгновение ока... 


КАК УСТРОИТЬСЯ НА 
ПЕРВУЮ РАБОТУ 


• МЕНТАЛЬНЫЙ НАСТРОЙ 


• ЭТАПЫ ПОИСКА ПЕРВОЙ РАБОТЫ ТЕСТИРОВЩИКОМ 


СОСТАВЛЕНИЕ РЕЗЮМЕ 

РАБОТА С АГЕНТСТВОМ ПО ТРУДОУСТРОЙСТВУ 
КОМПАНИЯ ПО РЕКЛАМЕ СЕБЯ 

ИНТЕРВЬЮ 


® ИСТОРИЯ ОБ ОЛЕ И ДЖОРДЖЕ 


[Г устроиться на первую работу так сложно? Ответ прост — 
интернет-компании нужен человек, который в минимальное 
время включился бы в ситуацию и начал приносить плоды, т.е. баги. 
Элементарная логика подсказывает, что все, кто работает в каче- 
стве наемного работника, однажды все-таки устроились на свою 
первую работу, а следовательно, это задача выполнимая. 


Перед тем как описать стандартный букет, состоящий из писем рабо- 
тодателю, резюме, интервью и прочего, я хочу рассказать о главном. 


Ментальный настрой 
Главным является ваше отношение к потенциальной первой 
работе. 
Итак, без прелюдий: 


Вы должны искренне хотеть работать. 

Вы должны быть готовы работать нелимитированные часы. 
Вы должны быть готовы работать в выходные и праздники. 
Вы должны быть готовы работать... бесплатно. 
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Если вы сможете принять эти советы как истину, то я на 90% га- 
рантирую, что в течение 3 месяцев вы найдете себе первую работу 
в качестве тестировщика в любом месте Вселенной, где есть хотя 
бы одна интернет-компания. 10% я оставил себе в качестве 
аргумента для защиты от обвинений. 


Отвлечемся от всего вышесказанного. 


Допустим, вам нужен домашний работник, чтобы подметать, 
готовить, стирать, гладить и выгуливать. Как бы вы отреаги- 
ровали на предложение, чтобы все эти услуги предоставлялись 
вам за ЛЮБУЮ сумму, которую вы сами назначите, работник 
горел искренним желанием видеть ваш пол блестящим, как глаза 
восточной красавицы, его можно было вызвать в любое время 
дня и ночи, работа была бы сделана добросовестно, и все это за 
то, чтобы дать ему... небольшой кредит на ошибку, так как он 
хорошо знает, как исполнить все требуемое от него, но в 
теории? Добавьте к этому, что вы сделаете доброе и 
благородное дело, дав своему брату возможность получить 
опыт работы, который сможет его кормить всю жизнь. Я 
такого работника взял бы и даже научил готовить утку по- 
пекински. 


Далее. 


Представьте себе, что он проработан у вас какое-то время, 
всему научился и стал конкурентоспособен на жестоком рынке 
‘услуг. Если вы им бесконечно довольны, станете ли вы полноцен- 
но платить ему как профессионалу, чтобы оставить его у себя, 
или же будете искать равноценного профессионала на стороне? 
Я ничего не понимаю в домашнем хозяйстве, если кто-то смо- 
жет всерьез утверждать, что лучше найти кого-то на стороне. 
На худой конец, даже если бы моя ситуация изменилась и 
начисто отпала потребность в услугах, то я дал бы этому 
изумительно трудолюбивому и бескорыстному человеку лучшие 
рекомендации. 


Вы скажете, что так не бывает, чтобы кто-то на самом деле рабо- 
тал на совесть и при этом не получал высокую заработную плату. 
Могу вас заверить, что так же думают менеджеры, которые и на- 
нимают нашего брата-тестировщика. Дело в том, что им, так же 
как и вам, никто никогда не предлагал добросовестно и нели- 
митированно работать почти исключительно за получение опыта. 
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И они, так же как и вы, откликнутся на то, чтобы помочь и вам, и 
в первую очередь себе. Так возьмите и предложите им такой 
вариант. Как это сделать, мы обсудим через минуту. 


Этапы поиска первой работы 
тестировщиком 


Итак, теперь поговорим о поиске первой работы тестировщиком 
поэтапно. 


0. Настройте себя в соответствии с принципами, о которых мы 
только что говорили. Люди, принимающие решения, почувствуют 
ваш настрой, ваше желание и ваше отношение. 


Основная задача данного этапа — настроиться на боевой лад. 


1. Обзвоните своих знакомых и расскажите о своем желании 
работать тестировщиком, желании работать сколько угодно, 
когда угодно и на любых условиях по оплате. Может быть, 
кто-то сможет помочь, хотя на знакомых рассчитывать не стоит, а 
рассчитывать стоит только на себя, и поэтому мы идем дальше. 


Основная задача данного этапа — забросить удочку. 


2. Займитесь составлением резюме. Резюме — это реклама. Ре 
ципиентами этой рекламы являются рекрутеры и работодатели. В 
отличие от телерекламы, которой можно пичкать мозги беско 
нечно и добиться потребительского зомбирования, у резюме есть 
только один и он же последний шанс, чтобы заинтересовать и 
заставить позвонить вам или прислать е-мейл с приглашением на 
интервью. Если резюме не использует этот шанс, то в лучшем 
случае оно оказывается в пачке своих собратьев, отложенных "до 
лучших времен", а в худшем — в реальной или виртуальной кор 
зине для мусора. 


Резюме — это презентация ваших знаний и добродетелей. По- 
нятие "презентация" играет здесь главную роль. Именно от эф- 
фективности презентации в большей мере зависит, заинтересуют- 
ся вами или нет. 


Искусство эффективной презентации заключается в том, чтобы 
представить нужную информацию в максимально выгодном 
для себя свете и максимально понятной для реципиента форме. 
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Итак, у вас есть совокупность вещей, некоторые из них можно и 
нужно презентовать в резюме. 


Например, это опыт работы, который, как мы уже говорили, 
является одним из источников ожидаемого результата. 


Задача В ТОМ, чтобы повернуть вещи под углом, ярко демонстри- 
рующим навыки, полезные именно для тестировщика. 


Например, Алла М. работает инженером полиграфического обо- 
рудования. 


Вопрос: имеет ли значение ее опыт установки и отладки вер- 
стальных машин фирмы Н. для ее резюме на должность тести- 
ровщика? Ответ: почему бы и нет, если мы это дело грамотно 
преподнесем. 


Пример грамотной презентации 


"Составила план по тестированию установки и отладки верстальных 
машин фирмы Н. Обнаружила критические заводские дефекты до на- 
чала эксплуатации и скоординировала их устранение с немецкой сто- 


роной". 


В общем думаю, что идея понятна. Учтите, что специальности 
"тестировщик" не учат ни в одном университете мира. Про- 
фессиональные тестировщики — это, как правило, профессионалы 
из десятков других профессиональных областей. 


Например 


Прошлые специальности некоторых моих знакомых — блестящих тес- 
тировщиков: архитектор, учитель, инженер, бухгалтер, биолог, метео- 
ролог, юрист, программист. 


Очень часто тестировщиками нанимают специалистов из той области, 
в которой работает компания (например, компания, выпускающая ПО 
для диагностики работы почки, естественно, предпочтет в качестве 
тестировщика человека с дипломом врача). 


Кстати, где бы вы ни работали, заведите себе маленький симпатичный 
текстовый файлик, куда, отбросив ложную скромность, постоянно за- 
писывайте каждую хорошую вещь, которую вы сделали. 


Например, коллега из соседнего отдела попросил вас научить его поль- 
зоваться неким тест-тулом, что вы и сделали. Знаете, как это называ- 
ется? Не "Подсобил тут давеча Петровичу", а "Обучение персонала", 
и вы вполне можете оперировать этой фразой в качестве, например, 
аргумента для своего продвижения по службе. Помните, что все ваши 
коллеги, особенно в западных компаниях, такой файлик ведут очень 
исправно, так как их этим вещам начинают учить еще в средней школе. 
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Нужно понять, что вы делаете много полезных вещей для компании, 
а они просто-напросто забываются и вами, и вашим менеджментом, 
так что записывайте свои хорошие дела и используйте эти записи в ко- 
рыстных целях. 


В отношении образования. Конечно, институт или университет 
выглядят на резюме лучше, чем 8 классов и курсы по вождению 
автомобиля. Но в любом случае отличной приправой для любого 
резюме будут свежепрослушанный курс по программированию, 
тестированию и/или другим околоинтернетовским дисциплинам, 
как, например, Руој/есі Мапазетети. 


Пусть это прозвучит банально, но английский действительно яв- 
ляется большим плюсом хотя бы потому, что на нем написана 
почти вся профессиональная литература. 


Покопайтесь в Интернете и найдите резюме тестировщиков, из 
них можно почерпнуть много полезного в отношении содержания 
и формата. 


Поговорите со знакомыми, может, кто-то имеет опыт в составле- 
нии резюме или даст полезный телефончик своего знакомого, 
который может не остаться равнодушным. 


Основные задачи данного этапа: 


а) начать переосмысление своего опыта с точки зрения его 
полезности для тестирования; 

б) составить черновую версию резюме. Используйте мето 
дику Черновик-чистовик с ее мозговым штурмом. 


3. Найдите агентства по трудоустройству, которые работают 
с интернет-компаниями. Как найти такое агентство? Например, 
пути аи 6: 


а) многие крупные рекрутерские организации дают рекламу с 
указанием имен своих именитых клиентов — компаний; 

б) если интернет-компания нанимает через агентство, то на 
объявлениях (в газетах, Интернете и на заборе) о вакансии 
дается название и телефон не самой компании, а этого 
агентства. 


Обзвоните найденные вами агентства и договоритесь о встречах 
с конкретными рекрутерами, которые занимаются поиском кан- 
дидатов в софтверные компании. Встретьтесь с ними, честно 
опишите свою ситуацию об отсутствии опыта в интернет-тес- 
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тировании и сделайте акцент на своем желании и настрое рабо- 
тать сколько угодно, когда угодно и на любых условиях по 
оплате. 


Запомните, что это желание и этот настрой являются вашими 
главными козырями при поиске первой работы тестировщиком. 


Стоящий профессионал как минимум даст вам рекомендации по 
стратегии и тактике поиска работы на местном рынке труда, а 
максимум позвонит в компанию, с которой он работает, и дого- 
ворится об интервью — вашем первом интервью в качестве тес- 
тировщика. Не должно быть никакого стеснения в этих звонках и 
просьбах о встрече — каждый встречающийся с вами рекрутер 
справедливо надеется, что с его помощью вы оба заработаете 
деньги, следовательно, рекрутеры — это ваши лучшие союз- 
ники, и чем больше союзников вы найдете, тем выше шансы на 
приглашение на интервью. 


Попросите особо понравившегося рекрутера, чтобы он помог вам 
довести до ума ваше резюме. Я знаю, что существуют профес- 
сиональные составители резюме, о них ничего сказать не могу, 
так как их услугами никогда не пользовался. 


Обязательно включите в свое резюме три энергичные фразы: 


"Готов работать нелимитированные часы. Готов 
работать в выходные и праздники. Готов работать 
на любых условиях по оплате". 


Используйте для этих фраз жирный шрифт. 


Основные задачи данного этапа: 


а) получить максимум информации из первых рук о мест 
ном рынке труда; 
б) иметь на руках окончательную версию резюме. 


4. Начните кампанию по распространению своего резюме. Ос- 
новные каналы для передачи информации — ЭТО 


а) размещение резюме на специализированных сайтах, напри 
мер ууу. лоўођБѕ.сот (это сайт для поиска работы в США); 
б) рассылка своего резюме и сопроводительных писем 


потенциальным работодателям И 
рекрутерам, нанятым потенциальными работодателями. 
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Резюмеи сопроводительное письмо посылаются 


в ответ на объявление об открытой позиции или же 
просто как предложение своих услуг. 


Сначала запускаем в действие пункт а. Пусть себе висят наши 
резюмешки, как приманка, и ловят в свои коварные сети вни- 
мание рекрутеров и работодателей. Пункт а — это пассивный 
поиск, работающий на вас, когда вы спите, смотрите телевизор 
или попиваете кальвадос. Пункт а — это также обезличенный 
пассивный поиск, т.е. вы не обращаетесь ни к кому конкретно. 


Для достижения гармонии нам нужен активно-целевой поиск, т.е. 
пункт б. Он подразумевает постоянную рассылку резюме и со- 
проводительных писем конкретным реципиентам. 


Подробности: 


а. Покопайтесь в Интернете и найдите несколько сайтов, на 
которых можно выставить свое резюме. Я обычно пользу 
юсь 3—5 сайтами, работающими с компаниями в районе 
моего проживания. Создайте эккаунты на каждом из сай 
тов и разместите на них свое резюме. Что делать дальше? 
Начать жизнеутверждающую активность в соответствии с 
пунктом 6. 

б. Интернет изобилует сайтами с вакансиями. Среди них, ес 
тественно, есть вакансии тестировщиков. Что мы делаем? 
Правильно: мы отправляем по контактным е-мейлам и фак 
сам наши резюме и сопроводительные письма. 


Теперь начинаются нюансы. 
Резюме, которое у вас есть, — это всего лишь шаблон. 


Иногда его можно послать в неизменном виде, иногда подогнать 
(в хорошем смысле этого слова) под вакансию. 


Например, если продукт компании — это сайт по онлайн-платежам, а 
у вас есть финансовое образование и опыт работы в банке с ведущими 
системами кредитных карт, то на такое образование и такой опыт ра- 
боты стоит сделать особый упор, изменив свое резюме. 


Я знаю нескольких тестировщиков, которые были взяты без 
опыта тестирования и на высокую заработную плату исключи- 
тельно из-за своего предшествующего релевантного опыта. Логи- 
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ка здесь проста — тестированию научиться легче, чем, скажем, 
квантовой физике. 


Теперь о сопроводительном письме. 


Вакансия может быть размещена компанией напрямую или же 
через агентство. В обоих случаях основная мысль вашего сопро- 
водительного письма — это убедить реципиента в своем настрое 
работать сколько угодно, когда угодно и на любых условиях 
по оплате. 


Для первого случая (вакансия идет напрямую от компании) мож- 
но также написать, что вся ваша жизнь была лишь прелюдией И 
томительным ожиданием работы именно в этой компании и 
именно в этой должности. 


Для второго случая можно написать о прелюдии и ожидании в 
отношении только вакансии, так как имя компании, которой 
можно было бы петь дифирамбы, хранится агентством в глубо- 
кой тайне. 


. 


Логичным будет следующий вопрос: "в описании любой вакан- 
сии будет указан минимальный стаж: (в годах) работы тести- 
ровщиком, необходимый для успешного кандидата. Какой смысл 
мне посылать свое резюме и сопроводительное письмо, если у 
меня нет и дня стажа?" 


Очень хороший вопрос. Я могу даже добавить, что это будет 
минимум 3 года и что если бы первый раз в истории человече- 
ства потребность в работе тестировщика появилась 1 марта, 
то 2 марта того же года кто-нибудь обязательно догадался бы 
обусловить в вакансии тестировщика тот же трехлетний 
стаж:. 


Шутки шутками, а реальность заключается в том, что требова- 
ния подавляющего большинства вакансий завышены. Это 
ситуация, в которой все всё понимают и просто играют свои 
роли. Ваша роль — это роль человека, которому нужна пер- 
вая работа, и вы должны сделать все возможное, чтобы уст- 
роиться. 


Так вот, считайте, что во "все возможное" входит и такая на пер- 
вый взгляд безнадежная вещь, как направление резюме и сопро- 
водительного письма в ответ на вакансию с требованием много- 
летнего стажа. 
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Одним из контраргументов идеи о "безнадежности" может 
послужить вероятность того, что в компании могут быть в 
наличии либо могут планироваться вакансии тестировщиков с 
другими навыками и/или другим опытом работы и/или другим 
стажем. И вообще, если перефразировать слова Филиппа Филип- 
(Д 


повича "Безнадежность живет в головах, а не на рынке труда ", 
тестировщики будут нужны всегда. 


Другим контраргументом может послужить тот факт, что 
та сакраментальная лягушка все-таки взбила молоко в масло, не 
зная теории маслобойного процесса, а вы имеете преимущество, 
зная, что в процессе трудоустройства одним из основных 
принципов является неутомимая пальба из всех орудий по 
всем 


• видимым (активный поиск) и 
• невидимым (пассивный поиск) мишеням. 


Кроме специализированных рекрутерских сайтов практически 
каждая интернет-компания имеет линк на список своих открытых 
позиций. Найдите как можно больше компаний, имеющих офисы 
в районе вашего географического обитания/интереса, и пошлите 
им свое резюме и сопроводительное письмо с подгонкой и под- 
халимажем, о которых мы уже говорили. Если даже в списке 
работ нет позиций тестировщиков, то используйте контактные е- 
мейл/факс, чтобы заявить о себе. 


Еще раз. Ложная скромность и стеснительность в процессе по- 
иска работы абсолютно неуместны. Вы ни у кого ничего не 
просите. Это чистой воды бизнес для вас, для рекрутера и для 
компании. 


Когда вас возьмут на работу, то с вашей помощью будут зара- 
батывать деньги и рекрутер (если он принимал участие), и ком- 
пания. В это время вы, кстати, будете горбатиться за четве- 
рых, не видя жены, детей, друзей и любимых попугаев. Так что 
идите напролом и да сопутствует вам удача! Л стесняются 
пусть те, кто получил свои должности не из-за знаний, тачанта 
и умения "пахать", а из-за других, не связанных с работой дос- 
тоинств. 


Основываясь на личном опыте и опыте моих знакомых, могу ут- 
верждать, что 300 резюме и 300 сопроводительных писем будет 
достаточно, чтобы быть приглашенным на несколько интервью, 
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одно из которых закончится приглашением на работу. Поиск ра- 
боты — это тоже работа, требующая времени, усилий, напряже- 
ния и волнительного ожидания звонка или е-мейла. 


5. Интервью — это сладкое и волнительное слово для любого 
наемного работника. Будь это первое или тридцать первое интер- 
вью — каждый раз это новый, уникальный и полезный опыт. Ин- 
тервью на первую работу по новой специальности — это особая 
песня, которая требует особых ритма, мелодии и слов. 


Запомните, что если вы будете серьезно, не покладая рук ис- 
кать работу, то с вами обязательно захотят встретиться. Мо- 
гут пройти недели или даже месяцы, но однажды с вами свя- 
жутся. Я это знаю. Я был там... Дальше все очень просто: вы 
подъедете к зданию за 30 минут до назначенного времени, найде- 
те нужный офис, выйдете на улицу, за 1 минуту до встречи вер- 
нетесь к офису, сделаете глубокий вздох, откроете двери и, шаг- 
нув как на плаху, улыбнетесь секретарше: "Добрый день, меня 
зовут Иван Иванов, и у меня назначено интервью с Петром Алек- 
сандровичем". 


Итак, начинаем... 


Стоп. Интервью начинается не в офисе потенциального работо- 
дателя, а дома. Домашняя работа перед интервью включает: 


• наведение справок о компании: вид бизнеса, партнеры, кон- 
куренты, рынок, на котором работает компания. 


Пример 


Однажды я устраивался в одну известную финансовую компанию. Перед 
интервью мною было прочитано множество статей в Интернете об этой 
компании и было выяснено, что львиная доля доходов компании идет в виде 
комиссии от транзакций после окончания онлайн-аукцио-нов. Я был очень 
рад узнать об этом, так как являюсь экспертом в этих самых аукционах и 
многолетним пользователем аукционных сайтов. Естественно, что на 
интервью я переводил тему именно на аукционы — предмет, в котором я 
себя чувствовал, как рыба в воде. На следующий день мне позвонили с 
предложением о работе. 


Пример 


Один мой знакомый, назовем его Витя, был на интервью в компании М. на 
пике ее популярности. Компания занималась разработкой сети Р2Р (реег- 
і0-реег), по которой распространялись трЗз файлы. Тогда только 
начинались разговоры о возможности ее закрытия по причине пару- 
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шения авторских прав. Витя спросил, есть ли план на случай, если суд 
перекроет кислород? Как выяснилось, никакого плана у компании не 
было. Витя успешно прошел интервью, раскланялся и пошел на интер- 
вью в другую компанию (в которой, кстати, до сих пор и работает). Что 
случилось с компанией М. ? Звукозаписывающие фирмы подали в суд, 
и через полгода компания была закрыта. 


Таким образом, наведя справки, Витя избавил себя от необходимости 
снова искать работу через полгода; 


• поиск знакомых (или родственников) либо знакомых зна 
КомЫХх, работающих в компании. 


Одна моя московская подруга, устраиваясь на работу, за 
день до интервью выяснила, что муж ее двоюродной сест- 
ры является вице-президентом той самой компании. На 
интервью идти не пришлось — и так взяли; 


• если возможно, использование веб-сайта компании. 


Например, купите самую дешевую вещь, продаваемую на 
веб-сайте компании, прочуствуйте бизнес, пользуясь им. 
Такие знания дорогого стоят во время интервью; 


• глажку костюма, стрижку головы, бритье щетины, чистку 
обуви и... хороший сон. 


Эти, казалось бы, элементарные вещи постоянно забывают 
те, кто приходит на интервью. Встречают по одежке (и по 
виду), и, как известно, доброе начало полдела откачало. 
Приходите на интервью опрятными, чистыми и свежими. 


Не могу не рассказать об одном курьезном случае, когда некий 
товарищ пришел на интервью в крупную западную компанию в 11 
утра... пьяным. С ним, конечно, поговорили, при этом без дураков, 
обнаружив превосходный интеллект и релевантный опыт 
работы, но на работу брать не стачи. Если он явился пьяным на 
интервью, когда каждый стремится показаться лучше, чем он 
есть, то каким он будет, возьми мы его на работу? 


Кстати, очень часто с вами сначала разговаривают по телефону 
(оһопе іпіегиіеи/ѕсгеепіпд). Как правило, вам звонит сотрудник отдела 
кадров и задает вопросы по списку, переданному ему менеджером 
тестировщиков. Знайте, что эти господа из НК (Нитап Кеѕоигсеѕ — от- 
дел кадров), как правило, не знают ничего из того, о чем спрашивают 
(имеются в виду чисто профессиональные знания тестировщика, на- 
пример методология создания тест-кейсов), им это и не надо, так как 
у каждого своя работа. После телефонного интервью листочек с во- 
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просами и вашими ответами передается обратно менеджеру, и если 
тот считает, что имеет смысл встретиться, то раздается столь долео- 
жданный для вас звонок и вы собираетесь на реальное интервью. 


Итак, "Добрый день, меня зовут Иван Иванов, и у меня назначено 
интервью с Петром Александровичем". 


Нюансы живого интервью: 


1. Приходите на интервью вовремя. 


Пробки на дорогах, подруги детства, встретившиеся на пути, 
борьба с последствиями некачественной яичницы, пропущенная 
последняя электричка — ничто из этого не волнует того, кто 
должен вас интервьюировать. Приезжайте раньше и походите 
полчаса кругами вокруг здания или почитайте книжку о бизнесе 
компании, но к Петру Александровичу должны позвонить, что вы 
пришли ровно в назначенное время: ни до, ни после. 


2. Жмите руку крепко и уверенно и смотрите собеседнику в 
глаза. 


Вам нечего скрывать или стесняться. Вы хотите, можете и, если 
вам дадут возможность, будете работать добросовестно и про- 
дуктивно. Интервьюирующий вас не Бог, не гений, а такой же 
человек, может быть, даже сидевший на вашем кресле интер- 
вьюируемого еще месяц назад. 


3. Вот несколько общих советов для поведения на интервью: 


• отвечайте на вопросы без груза лишних деталей (но да- 
вайте понять, что стоит интервьюирующему попросить — 
и детали будут даны). 


Иллюстрацией может послужить пример ситуации при интервью, 
которое провели родители одной девушки с соискателем ее руки 
и сердца. 


Соискатель (мой приятель) был приглашен в их квартиру, очень 
мило посидели, поговорили о том о сем. Приятель расслабился, в 
один момент в разговоре возникла пауза, и он, чтобы ее запол- 
нить и заодно блеснуть эрудицией, спросил у мамы невесты: «Вы 
знаете, я все время путаю Моне и Мане. Кто из них написач 
"Подсолнухи "?» После этого вопроса даже магнитофон, интел- 
лигентно проигрывающий сочинение маэстро Сальери, поста- 
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вил себя на паузу, предвкушая кровавую развязку. Наступила 
„мертвая тишина. И в этой тишине полный презрения голос д0- 
чурки произнес: «"Подсолнухи" написач Ван Гог». После этого 
разговор как-то сам собой свернулся. Авторитет был потерян, и 
этот никчемный в общем-то вопрос стал началом конца и в 
отношениях. И хотя семейка, включая доченьку, оказачась, как 
впоследствии выяснилось, совершенно мерзопакостной, мой при- 
ятель навсегда вынес урок об опасности лишних деталей во вре- 
мя интервью. 


Кстати, недавно, бродя по залам с работами импрессионистов в Мет- 
рополитен-музее, я увидел картину с чудесными подсолнухами. По- 
дойдя к картине, я прочел имя автора: Свиае Мопее.. 


• будьте вежливы и корректны. Не надо фамильярностей, 
анекдотов о теще и баек из жизни вашего полка на постое 
в городе Большие Щеглы. Быть профессионалом — это не 
только иметь опыт и знания, но и знать, что, как, где и ко- 
гда говорить. А вдруг интервьюирующий любит свою тещу, 
как мать родную? 


Вообще представьте себя в роли интервьюирующего: вы зани- 
маетесь каким-то интересным делом, например, бродите по веб- 
сайтам в поисках новых часов. К вам подходит ваш менеджер и 
говорит: "Вот резюме, кандидат сидит в той комнате, пойди 
поговори с ним без переводчика ". И вот вы неохотно заходите в 
"ту комнату", на ходу просматривая резюме, придумывая умные 
вопросы и прикидывая, сколько времени это дело займет, а то 
есть хочется... за углом новую шашлычную открыли... И если 
кандидат тактичен, вежлив и приветлив, то, конечно, приходит 
понимание того, что бурчащий желудок, измученный капучино, 
может подождать лишние 15 минут. Ничего не жачко для 
такого вежливого и приятного человека, который так сильно 
хочет работать; 


• проявите искренний интерес к вещам, о которых интер- 
вьюирующему говорить приятно. Дайте ему выговориться. 


Например, на одном интервью я спросил, используют ли в компании 
язык Руіһоп, в ответ на это интервьюирующий 20 минут рассказывал 
мне о том, какие тупы он пишет и как много денег они сэкономили ком- 
пании. Моя часть диалога заключалась в заполнении пауз словом "Вау". 
Мы расстались лучшими друзьями, и на следующий день я был при- 
глашен на работу. 
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Сплошной Карнеги, одним словом; 


• никогда, никогда не говорите плохо о фирмах, в которых 
вы когда-то работали! Это против правил. 


Лучше сочините что-то, но ни в коем случае не ругайте фирму, в 
которой вы работали прежде (даже если деятельность компании 
была не в сфере Интернета и вы работали там не тестировщиком, 
а бухгалтером). 


Пусть даже ваша святая правда в том, что начальник был полным 
дебилом и вы, светочи и душки, были окружены "сволочами, 
склочниками, приспособленцами и подхалимами" и пришлось 
уйти от этой шайки не по своей вине. О своем предыдущем 
работодателе, как о покойнике, — либо хорошо, либо ничего. 


Много хороших кандидатов погорело на интервью из-за своей 
откровенности. 


4. Еще раз: помните, что во время интервью анализируются 
не только ваши знания, но и ваша личность. Ответьте, с 
кем вам будет приятнее работать: 


а) с превосходным специалистом, от которого независимо от 
его профессиональных качеств постоянно несет луком и 
пережаренной свининой, который всех считает тупицами, 
потихоньку подсиживает своего начальника, и слывет сно 
бом или 

б) с начинающим специалистом, который самоотверженно 
пытается дойти до сути, на которого всегда можно поло 
жится, который искренне заинтересован в работе, друже 
любен, открыт и честен? 


Я, конечно, сгустил краски, но думаю, что идея понятна — лич- 
ность играет не меньшую роль, чем профессионализм, так как 
тот, кто вас интервьюирует, такой же наемный работник, 
большая часть времени его бодрствования проходит в стенах 
компании, и естественно, что для него очень важно, чтобы 
рядом были приятные, надежные и искренние люди. 


Лично для меня ответ очевиден. Выбираю вариант 6: по крайней 
мере, я сам ночей не досплю и ленчей не доем, но научу хорошего 
человека тому, что знаю. 
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5. Искренность подкупает. Ложь и желание скрыть что-то 
отталкивает. Вы не можете знать ответы на все вопросы, так 
как 
• интервьюирующий знает то, что не знаете вы (как и вы 

знаете то, что не знает он), 
• вы приходите в компанию как начинающий специалист. 


Итак, когда вам задают вопрос, ответ на который вы на 100% не 
знаете: 


НЕ НАДО: 


• морщить лоб; 

• шевелить губами; 

• направлять глаза в правый верхний угол (признак сочине- 
ния чего-либо); 

• всякими другими способами изображать усилия по расчи- 
стке завалов в памяти. 


Завалы-то, конечно, есть, но под ними ответа на вопрос нет. 


НАДО: 
Сказать сразу же две вещи: 


"Я незнаю" (свидетельство искренности) и сразу же уверенно 
вдогонку: 

"Но если это будет нужно для работы, я обязательно узнаю 
(научусь, прочитаю, выучу и т.д.)" (свидетельство желания учить- 
ся и совершенствоваться). 


Вещи из институтских баек о сдаче зачетов, когда абсолютно не 
знающий студент получает пятерку путем шокирования препода- 
вателя неожиданно оригинальным и абсурдным ответом, на ин- 
тервью не проходят. 


Желание учиться — одно из главных ваших достоинств, на 
которое нужно делать акцент каждый раз, когда вы не знаете 
ответа на вопрос. 


6. Даже если интервью не идет или не прошло гладко, не от 
чаивайтесь, не делайте никаких резких телодвижений, про 
должайте быть дружелюбны и вежливы. 


На одном из моих первых интервью я был так расстроен тем, 
что не смог ответить на большинство вопросов, что, после того 
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как интервьюирующий пошел за колой для себя и для меня, был 
на грани того, чтобы сбежать из комнаты, из здания, рвануть 
куда глаза глядят, потом сидеть в квартире, зачивая с дружками 
горе, жачея себя и обвиняя мир в несправедливости. Но я остался, 
прошел интервью и через несколько дней вышел на работу. Кто 
знает, говорил бы я с вами о тестировании, поддайся я тогда 
своему малодушному порыву... 


Запомните, что даже если вы на 100% уверены, что интервью 
проваливается (или уже провалилось), или, наоборот, идет (окон- 
чилось) прекрасно, ваша оценка не имеет никакого веса, так как 
решение о вашем найме или не найме принимаете не вы. Поэтому 
расслабьтесь и постарайтесь получить максимум удовольствия и 
знаний. 


Кстати, никогда не отказывайтесь от интервью. Каждое ин- 
тервью — это 


• уникачъный шанс узнать вопросы, ответы на которые вы 
не знаете... пока не придете домой и не возьмете книжку, 
не залезете в Интернет или не позвоните своим друзьям. 
Естественно, в следующий раз на тех же вопросах вас 
врасплох не поймают; 

• уникальный опыт обмена информацией с коллегами-тес- 
тировщиками; 

• уникальная возможность шлифовки своих навыков об- 
щения. 


Ходите на все интервью. 


Один мой знакомый, будучи уверен в том, что интервью в ком- 
пании А. прошло чики-пики, позвонил и отменил запланированное 
интервью в компании Б. Из компании А. никто не позвонил, а 
когда знакомый опомнился, компания Б. уже нашла себе тес- 
тировщика. 


В общем самый лучший вариант — это когда вы прошли интер- 
вью в две или больше компаний, сидите на кухоньке, разложив 
перед собой предложения о работе, и выбираете, в какую компа- 
нию лучше податься: "Так, сюда дачьше ехать на 20 минут, а 
здесь мне менеджер не особо понравился, а здесь проект какой- 
то лажовый". И дачьше в том же духе, т.е. уже не вас, а вы 
выбираете. Сладкое чувство... 
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7. Помните о ваших главных аргументах: 


"Готов работать нелимитированные часы. Готов 
работать в выходные и праздники. Готов 
работать на любых условиях по оплате". 


Один из тех, кто впоследствии стал ведущим тестировщиком не- 
кой западной компании, только недавно приехал из России и по- 
этому говорил с очень сильным акцентом. Очень сильным. Таким 
сильным, что, даже покупая гамбургер в "Макдоналдсе", всегда 
должен был повторять номер заказа: 


— Митьег 3, ріеаѕе. 

— Ехсиѕе те? 

— Сап Грауе питђег гее, р[еазе? 
— Ишсй питђег? 

— М№итрег іћгее. 

— Тигее? 

— Үе, Шгее. 

— Соі й. П маѕ Шгее, пе? 


Молодой человек отучился в колледже и на курсах тестировщи- 
ков (ни колледж:, ни курсы акценту особо не помогли). В один из 
дней его пригласили на интервью в ту самую западную компанию. 
Он пришел и переговорил с менеджером отдела тестирования. 
После менеджера его проинтервьюировал сотрудник отдела. На 
следующий день молодой человек получил предложение о работе 
и лишь через четыре года узнал все подробности, а подробности 
таковы: 


Выйдя из комнаты, менеджер понят, что из всего сказанного этим 
русским он на сто процентов понят только одну фразу "Выл 
ворк дэй энд найт" ("ИЛИ уотк дау апа шем" — Буду работать 
день и ночь). 


Кроме того, этот молодой человек постоянно показывал на свой 
мобильный телефон и часы, из чего можно было сделать вывод о 
том, что его можно будет вызвать в офис в любое время. С не- 
много ошарашенным видом менеджер подошел к сотруднику 
отдела тестирования и сказал: 


— Сдается мне, Джим, что этот парень не совсем хорошо гово 
рит по-английски. Но зато какое отношение к работе!!! Пойди- 
ка и поговори с ним на любую тему: о природе, ценах на нефть, 
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скучает ли он по России. Самое главное, что тебе нужно выяс- 
нить: будешь ли ты в принципе понимать его. 


Джим пошел и поговорил, потом пришел к менеджеру и сказан 


— Конечно, акцент у него будь здоров, но дело в том, что я вырос 
в среде русских в городе Чикаго и даже немного говорю по-рус- 
ски. Так что надо брать. Этот будет работать за троих. Да и 
на предложенную нами зарплату сразу согласился. 


Нужно сказать, что ни менеджер, ни Джим ни разу не пожа- 
лели о своем решении. 


8. Вот краткий список вопросов на интервью с моими реко- 
мендациями по ответам: 


Почему вы решили стать тестировщиком? 


Ответ: 

Потому что работа тестировщика требует творческого подхода, 
мне всегда нравилось анализировать ПО и искать баги в нем, я 
всегда мечтал быть частью интересного интернет-проекта. Счи- 
таю, что у меня есть качества, которые помогут мне стать эффек- 
тивным профессионалом, например внимание к деталям, умение 
работать в условиях стресса, навыки в общении с людьми. 


Что больше всего вам нравится в тестировании? 


Ответ: 

С одной стороны, для меня важно, что тестирование — это и твор- 
чество, и интуиция, и профессиональные прикладные навыки, 

и каждый из этих трех компонентов важен и интересен для меня, 


с другой — тестирование мне нравится тем, что своей работой 
тестировщик приносит ощутимый и реальный результат, кото- 
рым является нахождение багов до того, как их найдут наши поль- 
зователи. 


Какими достоинствами должен обладать эффективный тес- 


тировщик? 

Ответ: 

1. Честность. 

2. Искренний интерес к своей работе и гордость за свою работу. 
3. Постоянное профессиональное совершенствование. 

4. Способность быстро переключаться с одной задачи на другую. 
5. Способность жертвовать личным временем в интересах работы. 
6. Умение работать с людьми. 

7. Умение сохранять эффективность в условиях стресса. 
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8. Возможность и желание работать нелимитированные часы, а 


также в выходные и праздники. 
Я думаю, что у меня есть все вышеперечисленные достоинства. 


Расскажите о своих краткосрочных и долгосрочных планах 


в карьере? Как работа тестировщика вписывается в них? 
Ответ: 

Я хочу стать экспертом в тестировании ПО. Краткосрочные планы — 
это устроиться на работу и применить мои знания в живом деле. 
Долгосрочные планы — это постоянное профессиональное совер- 
шенствование и, возможно, специализация по одному из направ- 
лений тестирования, например автоматизация регрессивного тес- 
тирования. Какими бы ни были мои планы в настоящее время, 
главный приоритет, если я буду нанят, — это на 110% выполнять 
требования, которые будет ко мне предъявлять работа в компании. 


Можете ли вы в случае крайних обстоятельств приехать в 


офис в любое время дня и ночи, если того потребует работа? 
Ответ: 

Да. Я готов приехать в офис 24 х 7х 365 (самое главное в этом от- 
вете — быстрота и уверенность, с которой он должен быть дан). 


Сможете ли вы в случае крайних обстоятельств работать 


в выходные дни и праздники? 

Ответ: 

Да. Работа прежде всего (самое главное в этом ответе — быстро- 
та и уверенность, с которой он должен быть дан). 


Сможете ли вы в случае крайних обстоятельств работать 


больше 8 часов в день? 

Ответ: 

Да. Я знаю, что работа тестировщика предполагает нелимитиро- 
ванные часы работы (самое главное в этом ответе — это быстрота 
и уверенность, с которой он должен быть дан). 


Можете ли вы работать одновременно с несколькими про- 


ектами? 
Ответ: 
Да. Я умею быстро переключать внимание и быстро концентриро- 


ваться на новой задаче. 


Как вы переносите давление времени? Менеджмента? 


Ответ: 

Я полностью осознаю, что работа в интернет-компании — это хотя 
и интересный, но тяжелый труд, когда все работники, включая ме- 
неджмент, находятся под давлением времени, акционеров, кон- 
курентов и прочее. И я готов и могу работать в такой среде. 
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Опишите опыт работы и образование, релевантные к тести- 


рованию. 
Ответ: 


(Ответ индивидуален. Акцентируйте вещи, имеющие отношение 
к тестированию, компьютерам и анализу.) 


Ваше самое большое профессиональное достижение (не- 


обязательно в области тестирования). 

Ответ: 

(Будьте готовы к такому вопросу и с гордостью расскажите о своем 
достижении.) 


Почему вы ушли (уходите) из своей предыдущей компа- 
нии? 

Ответ: 

Я хочу попробовать новую для меня профессию тестировщика. 
Мне нравилось (нравится) работать в моей компании. Я поль- 


зуюсь уважением своих коллег и менеджмента, но мне хочется 
применить СВОЙ ОПЫТ работы в новом для меня деле. 


Опишите свои самые большие разочарования на ваших пре- 


дыдущих работах. 

Ответ: 

У меня не было каких-либо больших разочарований. Мои приори- 
теты — это усердная работа и профессиональное совершенст- 


вование, ия считаю, что не место красит человека, а человек — 
место. 


Где бы вы предпочли работать: в большой устоявшейся ком- 


пании или в стартапе? Почему? 
Все ответы хороши, выбирай на вкус: 


а) в большой компании, так как в большой компании, где уже по- 
ставлены все процессы и уже есть штаттестировщиков, я смо- 
гу быстрее научиться и быстрее стать продуктивным, чем ра- 
ботая в маленьком стартапе; 

б) в маленьком стартапе, так как есть шанс участвовать в созда- 
нии процессов и становлении департамента качества с нуля, 
чего нельзя сделать в большой компании. 


Приведите пример сложной ситуации, с которой вы столкну- 


лись в своей карьере, и какой выход из нее вы нашли? 

Ответ: 

(Будьте готовы к такому вопросу и с гордостью опишите такую си- 
туацию.) 
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У каждого есть свои недостатки и достоинства. Приведите 
пример двух недостатков и двух достоинств. 
Ответ: 


(Будьте готовы к такому вопросу и имейте в запасе два маленьких 
недостатка и два больших достоинства. Пример маленького не- 
достатка: люблю играть в покер. Пример большого достоинства — 
готов работать нелимитированные часы, в выходные и праздники.) 


Что бы вы пожелали усовершенствовать в себе? Что вы для 
этого делаете? 

Ответ: 

(Будьте готовы к такому вопросу. Ну что можно усовершенство- 
вать? Например, свои программистские навыки.) 


Вы предпочитаете работать самостоятельно или в группе? 
Почему? 
Ответ: 


(Зависит от ваших личных склонностей.) 


Почему вы хотите работать именно в нашей компании? 
Ответ: 


(Вспомните, что вы узнали о компании, и расскажите о вещах, 
которые вас искренне привлекают в этой компании.) 


Что вы знаете о нашей компании? Пользуетесь ли вы нашим 
продуктом? 

Ответ: 

(Вспомните, что вы узнали о компании, и о ваших впечатлениях от 


пользования веб-сайтом компании — если, конечно, у вас была 
такая возможность. НЕ КРИТИКУИТЕ.) 


Почему вы хотите устроиться именно на эту позицию? 
Ответ: 


(Вспомните, что вы узнали о позиции, и скажите, что вы идеаль- 
ный кандидат, хотите работать и даже если чего-то не знаете, то 
непременно выучите в кратчайшие сроки.) 


Почему мы должны нанять вас в нашу компанию? 
Ответ: 


(Вспомните, что вы узнали о компании и позиции, и расскажите об 
их идеальном сочетании с вашей кандидатурой. Я не шучу.) 


Далее. 


Как правило, интервьюирует вас больше чем один сотрудник ком- 
пании. Иногда приходится приезжать в компанию несколько раз. 
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Как правило, после интервью интервьюирующие передают ме- 
неджеру свои субъективные мнения о качествах интервьюируе- 
мого, и менеджер на основе одного или более отзывов принимает 
решение. С вашей стороны хорошим тоном будет послать после 
интервью краткий е-мейл с благодарностью тому, кто вас интер- 
вьюировал. 


Запомните, что наем — это соединение двух потребностей: 


е потребности работника в нахождении компании и 
е потребности компании в нахождении работника. 


Каждый из нас на своей шкуре знает о потребности в работода- 
теле. Вот вам напоследок случай из жизни о потребности работо- 
дателя в работнике. 


История об Оле и Джордже 


Одна моя знакомая (назовем ее Оля) была нанята следующим об- 
разом. 


Компании М. срочно нужен был человек для тестирования мно- 
гомиллионного проекта. Время так прижимачо, что, как гово- 
рится, человек должен был начать работать вчера. 


Менеджер позвал одного из сотрудников (назовем его Жорж:), 
дач адрес проходящей по соседству ярмарки тачантов, вручил 
заполненный контракт с пустым полем "Имя" и сказал, чтобы 
бедный Жорж: не возвращачся, пока в этом пустом поле не бу- 
дет написано имя нового работника, а в том пустом месте не 
будет его (нового работника) подписи. 


Оля тогда работача тестировщицей в одном из стартапов, и ее 
послали на ярмарку, чтобы она раздавала рекламные проспекты 
своей компании, Ее энергичная, жизнеутверждающая 
деятельность привлекла внимание понурого и разочарованного 
Жоржа, тот подошел к ней, они познакомились, и он, к своей 
преждевременной радости, узнал, что Оля разбирается в тес- 
тировании. 


Загвоздка была в том, что она ни в какую не хотела менять 
место работы. Тогда Жорж:, которому было уже почти что 
нечего терять, решил применить старый, как мир, прием... 
спаивания и соблазнения и пригласил ее в хороший ресторан. 
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Там они непропорционачьно закуске выпили (причем в процессе 
потребления Жорж: умело комбинировал комплименты Оле с ком- 
плиментами своей компании), и между б-м и 7-м "дринками " со 
словами: "Не пожалеешь " (по-английски) — он шлепнул на стол 
контракт, который и был немедленно подписан с восклицанием: 


"А фигли " (по-русски). 


Это все о поиске первой работы. 


Краткое подведение итогов 
Самое главное — 


Вы должны искренне хотеть работать. 

Вы должны быть готовы работать нелимитированные часы. 
Вы должны быть готовы работать в выходные и праздники. 
Вы должны быть готовы работать... бесплатно. 


Вопросы для самопроверки 


Не буду я вас больше мучить, а просто скажу: 


Все получится. Удачи вам!!! 


ПОСЛЕСЛОВИЕ, 


Друзья, 


на прощание я хочу донести до вас некоторые идеи, которые сыг- 
рали в моей судьбе важную роль и которые могут быть реально 
позитивны для вас, хотите ли вы найти себе новую работу, встре- 
тить свою половинку или заработать денег на постройку детской 
больницы. 


..Каждый из нас хочет лучшей жизни. Но вот в чем дело: "стрем- 
ление к лучшей жизни" может быть 


• либо создаваемой нами реальностью, насыщенной мысля- 
ми о МЕЧТЕ и шагами к ее осуществлению; 

• либо мешаниной из пустой болтовни, оправданий, поисков 
виноватого и надежд на доброго царя, коммунизм или 
джек-пот. 


Каждый из нас: 


• либо выбирает собственный осмысленный путь и изо дня 
в день пробивает себе дорогу к своей цели, 

• либо изо дня в день выбирает (даже не признаваясь себе в 
этом выборе) адаптацию к обстоятельствам, созданным 
другими, и следование решениям, принятым другими 
(кстати, вопрос на засыпку: "Какова вероятность того, что 
тех "других" волнует ваше благополучие?"). 


Все очень просто: одно либо другое. Третьего не дано, как бы ни 
было это комфортно для мягкой теплой кошечки инертности и 
лени, которая сидит в каждом из нас. 


Вот, кстати, любимое мяу-мяу такой кошечки: 
"У меня было тяжелое детство, жизнь ко мне несправедлива, 


и вообще мне не везет". 
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Вот убедишь себя в таком, и все "хорошо" — мозги отключились, 
виноватые найдены, "наливай, Леха". 


А что, если попробовать признаться не кому-то, а себе, что, не- 
смотря на тяжелое детство, несправедливость жизни и отсутствие 
флаш-роялей каждые две минуты игры в покер, те проблемы и 
радости, которые у нас есть, — это плод наших собственных дей- 
ствий и мыслей и что, несмотря на то что у всех был разный 
старт и разная среда формировала и формирует нас, мы могли и 
можем изменить к лучшему наши судьбы? 


Простая правда жизни заключается в том, что каждый из нас 
МОЖЕТ, но не каждый из нас БУДЕТ. Спросите алкоголика, 
почему он пьет, и он вам даст четко уложенное в его голове "ве- 
сомое" оправдание, например: "Моя ранимая душа поэта только 
так может забыться: ведь жизнь — это такой бардак". Кстати, 
хорошим, хотя и небезопасным будет вопрос: "А что лично ты 
сделал, чтобы бардака стало меньше? Купил бутылку и оскорбил 
жену?" Не ищем ли мы себе таких же "весомых" оправданий, 
лишь бы не менять то, что есть, даже если это "то, что есть" пре- 
вращает дар жизни в прозябание, унижение и боль? 


Далее. 


Я прошел через тяжелый период жизни в чужой стране, положе- 
ние было порой совершенно отчаянным, и казалось, что не смогу 
здесь пробиться, нужно просто взять обратный билет и... начать 
разговоры о тяжелом детстве, несправедливости жизни и невезе- 
нии. НО у меня была МЕЧТА. И эта МЕЧТА давала мне силы, 
чтобы 


• спать по три часа в сутки, проводя ночи за компьютером и 
книгами, после того как я возвращался в снимаемую на 
двоих комнатку 2х3 метра со стройки (понедельник — 
пятница) или из ресторана (где я, к сожалению, не пировал, 
а работал официантом, порой обслуживающим стол на не- 
сколько десятков человек, которые, хрустя квашеной капуст- 
кой, одновременно ностальгировали по Советскому Союзу 
и нередко имели в своих рядах представителей, которые, 
не будучи людьми особо утонченными в трезвом состоя- 
нии, превращались в законченную шушеру в состоянии не- 
трезвом) (суббота, воскресенье); 

• рассылать сотни резюме и пытаться скрыть немыслимое 
волнение на редких собеседованиях, заканчивавшихся 
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"Те Ш са уои" ("Мы вам позвоним"), последующими 
днями ожидания и отсутствием звонка; • полностью, без 
выходных и праздников, отдаться проектам, на которые в 
конце концов меня пригласили. 


И сейчас я понимаю, что, хотя тот период был самым сложным в 
моей жизни, все труды стоили того, потому что это была моя 
МЕЧТА и я сделал все, что мог, для ее достижения, я не только 
добился того, чего хотел тогда, но и создал для себя большие 
возможности, чтобы помочь другим людям. 


Например, знания, которые я получил на пути к достижению 
МЕЧТЫ, позволили мне написать эту книгу, и я могу помочь вам 
получить новые оплачиваемые знания и в то же время помочь 
больным детишкам (по моему поручению издательство "Дело" 
переведет все авторское вознаграждение за эту книгу на рас- 
четный счет российской детской клинической больницы (РДКБ) 
(рир://ей.тзК.ги)). 


Далее. 


Не позволяйте никому отвести вас от вашего стремления к 
лучшей жизни. 


Нам, русским, из-за исторически сложившейся перманентной по- 
литической нестабильности и идейной неустроенности свойст- 
венны иррациональность и надежда на авось, и хотя нет сомне- 
ний в том, что в жизни всегда есть вероятность того, что можно 
получить удар, когда не ждешь и откуда не ждешь, все-таки каж- 
дый из нас (хотим мы того или нет) является хозяином собст- 
венной жизни, и если однажды не решить изменить ее к лучше- 
му, то не неудачники, которые промыли нам мозги своими сини- 
цами в руке, а лично каждый из нас будет с сожалением вспоми- 
нать об упущенных возможностях. 


Помните, как у Пелевина: "До чего загадочна и непостижима 
жизнь и какую крохотную часть того, чем она могла бы быть, 
мы называем этим словом"? Я никому не посоветовал бы ска- 
зать такое о своей жизни. 


Даже если вы придете к другому, нежели первоначальная цель, 
то это другое часто бывает гораздо лучше для вас, чем зара- 
нее запланированное. 
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Каждый день человек принимает решения: 


• когда он садится/не садится пьяным за руль — он прини- 
мает решение (три ударения: ударение на "ОН", ударе- 
ние на "ПРИНИМАЕТ", ударение на "РЕШЕНИЕ"); 

• когда он помогает/не помогает женщине, несущей от мет- 
ро неподъемные сумки, — он принимает решение; 

• когда он отвечает/не отвечает грубостью в ответ на то, что 
ему случайно наступили на ногу, — он принимает 
решение. 


Когда он вдруг просыпается посреди ночи и понимает, что его 
жизнь может и должна быть гораздо лучше, что он может при- 
нести намного больше пользы себе и окружающим, когда он 
чувствует кожей, что жизнь вполсилы — это не его путь, то он 
МОЖЕТ принять решение, которое в корне изменит его жизнь и 
будет началом благодарного пути человека, который сделал вы- 
бор идти за МЕЧТОЙ. 


Я желаю вам иметь МЕЧТУ и принимать мудрые решения, кото- 
рые сделали бы этот мир счастливее, а после вашего ухода оста- 
вили бы ростки благодеяний и добрую память. 


Здоровья вам, успеха, любви, долгих чудесных лет и покоя на 
сердце. 


С уважением и верой в вас, 
Роман Савин 
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наиважнейшие вещи, которые понадобятся тестировщику ПО. 


Его подход к преподаванию является сугубо практическим, 


лишенным показной академичности и основанным на 


успешной карьере самого автора. 
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Книга позволяет! потратив минимум временит получить 


не только обьемное представление о деятельности 


тестировщика, но и реальный практический инструмент 


обретения новой профессии. 
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